rust-analyzer/crates/test-utils/src/minicore.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

1649 lines
42 KiB
Rust
Raw Normal View History

//! This is a fixture we use for tests that need lang items.
//!
//! We want to include the minimal subset of core for each test, so this file
//! supports "conditional compilation". Tests use the following syntax to include minicore:
//!
//! //- minicore: flag1, flag2
//!
//! We then strip all the code marked with other flags.
//!
//! Available flags:
//! add:
//! asm:
//! assert:
//! as_ref: sized
//! bool_impl: option, fn
//! builtin_impls:
2023-04-28 17:14:30 +00:00
//! cell: copy, drop
//! clone: sized
2021-06-16 07:48:07 +00:00
//! coerce_unsized: unsize
2023-12-02 15:50:21 +00:00
//! concat:
//! copy: clone
//! default: sized
2021-06-16 07:30:29 +00:00
//! deref_mut: deref
//! deref: sized
//! derive:
//! discriminant:
//! drop:
2024-01-08 09:37:09 +00:00
//! env: option
//! eq: sized
//! error: fmt
2024-04-19 11:18:30 +00:00
//! fmt: option, result, transmute, coerce_unsized, copy, clone, derive
2021-06-16 07:48:07 +00:00
//! fn:
//! from: sized
2021-06-15 19:49:00 +00:00
//! future: pin
//! coroutine: pin
//! hash:
2023-06-04 08:02:11 +00:00
//! include:
//! index: sized
//! infallible:
2023-06-05 11:27:19 +00:00
//! int_impl: size_of, transmute
2021-06-16 19:48:48 +00:00
//! iterator: option
2021-06-18 20:48:18 +00:00
//! iterators: iterator, fn
2023-04-23 18:25:47 +00:00
//! manually_drop: drop
2023-06-25 22:27:12 +00:00
//! non_null:
2022-10-27 19:58:34 +00:00
//! non_zero:
2023-04-18 14:08:38 +00:00
//! option: panic
//! ord: eq, option
//! panic: fmt
//! phantom_data:
//! pin:
2023-11-14 09:08:19 +00:00
//! pointee: copy, send, sync, ord, hash, unpin
//! range:
//! result:
//! send: sized
2023-06-05 11:27:19 +00:00
//! size_of: sized
//! sized:
//! slice:
//! sync: sized
//! transmute:
//! try: infallible
2023-11-14 09:08:19 +00:00
//! unpin: sized
//! unsize: sized
2024-02-01 09:02:19 +00:00
//! todo: panic
//! unimplemented: panic
2023-01-20 22:09:35 +00:00
#![rustc_coherence_is_core]
pub mod marker {
// region:sized
#[lang = "sized"]
#[fundamental]
#[rustc_specialization_trait]
pub trait Sized {}
// endregion:sized
// region:send
pub unsafe auto trait Send {}
impl<T: ?Sized> !Send for *const T {}
impl<T: ?Sized> !Send for *mut T {}
// region:sync
unsafe impl<T: Sync + ?Sized> Send for &T {}
unsafe impl<T: Send + ?Sized> Send for &mut T {}
// endregion:sync
// endregion:send
// region:sync
pub unsafe auto trait Sync {}
impl<T: ?Sized> !Sync for *const T {}
impl<T: ?Sized> !Sync for *mut T {}
// endregion:sync
// region:unsize
#[lang = "unsize"]
pub trait Unsize<T: ?Sized> {}
// endregion:unsize
2021-06-18 19:10:29 +00:00
2023-11-14 09:08:19 +00:00
// region:unpin
#[lang = "unpin"]
pub auto trait Unpin {}
// endregion:unpin
2021-06-18 19:10:29 +00:00
// region:copy
#[lang = "copy"]
pub trait Copy: Clone {}
// region:derive
#[rustc_builtin_macro]
pub macro Copy($item:item) {}
// endregion:derive
mod copy_impls {
use super::Copy;
macro_rules! impl_copy {
($($t:ty)*) => {
$(
impl Copy for $t {}
)*
}
}
impl_copy! {
usize u8 u16 u32 u64 u128
isize i8 i16 i32 i64 i128
f32 f64
bool char
}
impl<T: ?Sized> Copy for *const T {}
impl<T: ?Sized> Copy for *mut T {}
impl<T: ?Sized> Copy for &T {}
2023-05-18 15:47:06 +00:00
impl Copy for ! {}
2021-06-18 19:10:29 +00:00
}
// endregion:copy
// region:fn
#[lang = "tuple_trait"]
pub trait Tuple {}
// endregion:fn
// region:phantom_data
#[lang = "phantom_data"]
pub struct PhantomData<T: ?Sized>;
// endregion:phantom_data
// region:discriminant
#[lang = "discriminant_kind"]
pub trait DiscriminantKind {
#[lang = "discriminant_type"]
type Discriminant;
}
// endregion:discriminant
}
2021-06-17 17:49:49 +00:00
// region:default
pub mod default {
pub trait Default: Sized {
fn default() -> Self;
}
// region:derive
#[rustc_builtin_macro(Default, attributes(default))]
pub macro Default($item:item) {}
// endregion:derive
// region:builtin_impls
macro_rules! impl_default {
($v:literal; $($t:ty)*) => {
$(
impl const Default for $t {
fn default() -> Self {
$v
}
}
)*
}
}
impl_default! {
0; usize u8 u16 u32 u64 u128 isize i8 i16 i32 i64 i128
}
impl_default! {
0.0; f32 f64
}
// endregion:builtin_impls
2021-06-17 17:49:49 +00:00
}
// endregion:default
2021-08-10 09:59:41 +00:00
// region:hash
pub mod hash {
pub trait Hasher {}
pub trait Hash {
fn hash<H: Hasher>(&self, state: &mut H);
}
// region:derive
#[rustc_builtin_macro]
pub macro Hash($item:item) {}
// endregion:derive
2021-08-10 09:59:41 +00:00
}
// endregion:hash
2023-04-28 17:14:30 +00:00
// region:cell
pub mod cell {
use crate::mem;
#[lang = "unsafe_cell"]
pub struct UnsafeCell<T: ?Sized> {
value: T,
}
impl<T> UnsafeCell<T> {
pub const fn new(value: T) -> UnsafeCell<T> {
UnsafeCell { value }
}
pub const fn get(&self) -> *mut T {
self as *const UnsafeCell<T> as *const T as *mut T
}
}
pub struct Cell<T: ?Sized> {
value: UnsafeCell<T>,
}
impl<T> Cell<T> {
pub const fn new(value: T) -> Cell<T> {
Cell { value: UnsafeCell::new(value) }
}
pub fn set(&self, val: T) {
let old = self.replace(val);
mem::drop(old);
}
pub fn replace(&self, val: T) -> T {
mem::replace(unsafe { &mut *self.value.get() }, val)
}
}
impl<T: Copy> Cell<T> {
pub fn get(&self) -> T {
unsafe { *self.value.get() }
}
}
}
// endregion:cell
2021-06-18 19:10:29 +00:00
// region:clone
pub mod clone {
#[lang = "clone"]
pub trait Clone: Sized {
fn clone(&self) -> Self;
}
impl<T> Clone for &T {
fn clone(&self) -> Self {
*self
}
}
// region:builtin_impls
macro_rules! impl_clone {
($($t:ty)*) => {
$(
impl const Clone for $t {
fn clone(&self) -> Self {
*self
}
}
)*
}
}
impl_clone! {
usize u8 u16 u32 u64 u128
isize i8 i16 i32 i64 i128
f32 f64
bool char
}
2023-05-18 15:47:06 +00:00
impl Clone for ! {
fn clone(&self) {
*self
}
}
// endregion:builtin_impls
2021-06-18 19:10:29 +00:00
// region:derive
#[rustc_builtin_macro]
pub macro Clone($item:item) {}
// endregion:derive
}
// endregion:clone
2021-06-17 17:58:05 +00:00
pub mod convert {
2021-09-29 12:04:32 +00:00
// region:from
2021-06-17 17:58:05 +00:00
pub trait From<T>: Sized {
fn from(_: T) -> Self;
}
pub trait Into<T>: Sized {
fn into(self) -> T;
}
impl<T, U> Into<U> for T
where
U: From<T>,
{
fn into(self) -> U {
U::from(self)
}
}
impl<T> From<T> for T {
fn from(t: T) -> T {
t
}
}
2021-09-29 12:04:32 +00:00
// endregion:from
// region:as_ref
pub trait AsRef<T: ?Sized> {
fn as_ref(&self) -> &T;
}
// endregion:as_ref
// region:infallible
2023-03-08 17:28:52 +00:00
pub enum Infallible {}
// endregion:infallible
2021-06-17 17:58:05 +00:00
}
2023-04-18 14:08:38 +00:00
pub mod mem {
2023-04-23 18:25:47 +00:00
// region:manually_drop
#[lang = "manually_drop"]
#[repr(transparent)]
pub struct ManuallyDrop<T: ?Sized> {
value: T,
}
impl<T> ManuallyDrop<T> {
pub const fn new(value: T) -> ManuallyDrop<T> {
ManuallyDrop { value }
}
}
// region:deref
impl<T: ?Sized> crate::ops::Deref for ManuallyDrop<T> {
type Target = T;
fn deref(&self) -> &T {
&self.value
}
}
// endregion:deref
// endregion:manually_drop
// region:drop
2023-04-18 14:08:38 +00:00
pub fn drop<T>(_x: T) {}
2023-04-28 17:14:30 +00:00
pub const fn replace<T>(dest: &mut T, src: T) -> T {
unsafe {
2023-05-18 15:47:06 +00:00
let result = crate::ptr::read(dest);
crate::ptr::write(dest, src);
2023-04-28 17:14:30 +00:00
result
}
}
// endregion:drop
// region:transmute
extern "rust-intrinsic" {
pub fn transmute<Src, Dst>(src: Src) -> Dst;
}
// endregion:transmute
2023-06-05 11:27:19 +00:00
// region:size_of
extern "rust-intrinsic" {
pub fn size_of<T>() -> usize;
}
// endregion:size_of
2023-07-14 16:45:18 +00:00
// region:discriminant
use crate::marker::DiscriminantKind;
pub struct Discriminant<T>(<T as DiscriminantKind>::Discriminant);
// endregion:discriminant
2023-04-18 14:08:38 +00:00
}
2023-05-12 14:47:15 +00:00
pub mod ptr {
// region:drop
2023-05-12 14:47:15 +00:00
#[lang = "drop_in_place"]
pub unsafe fn drop_in_place<T: ?Sized>(to_drop: *mut T) {
unsafe { drop_in_place(to_drop) }
}
2023-05-18 15:47:06 +00:00
pub const unsafe fn read<T>(src: *const T) -> T {
*src
}
pub const unsafe fn write<T>(dst: *mut T, src: T) {
*dst = src;
}
// endregion:drop
2023-04-30 20:34:11 +00:00
// region:pointee
#[lang = "pointee_trait"]
2023-11-14 09:08:19 +00:00
#[rustc_deny_explicit_impl(implement_via_object = false)]
2023-04-30 20:34:11 +00:00
pub trait Pointee {
#[lang = "metadata_type"]
2023-11-14 09:08:19 +00:00
type Metadata: Copy + Send + Sync + Ord + Hash + Unpin;
2023-04-30 20:34:11 +00:00
}
// endregion:pointee
2023-06-25 22:27:12 +00:00
// region:non_null
#[rustc_layout_scalar_valid_range_start(1)]
#[rustc_nonnull_optimization_guaranteed]
pub struct NonNull<T: ?Sized> {
pointer: *const T,
}
// region:coerce_unsized
impl<T: ?Sized, U: ?Sized> crate::ops::CoerceUnsized<NonNull<U>> for NonNull<T> where
T: crate::marker::Unsize<U>
{
}
// endregion:coerce_unsized
// endregion:non_null
2023-05-12 14:47:15 +00:00
}
2023-04-18 14:08:38 +00:00
pub mod ops {
// region:coerce_unsized
mod unsize {
use crate::marker::Unsize;
#[lang = "coerce_unsized"]
pub trait CoerceUnsized<T: ?Sized> {}
impl<'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<&'a mut U> for &'a mut T {}
impl<'a, 'b: 'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<&'a U> for &'b mut T {}
impl<'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*mut U> for &'a mut T {}
impl<'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*const U> for &'a mut T {}
impl<'a, 'b: 'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<&'a U> for &'b T {}
impl<'a, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*const U> for &'a T {}
impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*mut U> for *mut T {}
impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*const U> for *mut T {}
impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<*const U> for *const T {}
}
pub use self::unsize::CoerceUnsized;
// endregion:coerce_unsized
// region:deref
mod deref {
#[lang = "deref"]
pub trait Deref {
#[lang = "deref_target"]
type Target: ?Sized;
fn deref(&self) -> &Self::Target;
}
impl<T: ?Sized> Deref for &T {
type Target = T;
fn deref(&self) -> &T {
loop {}
}
}
impl<T: ?Sized> Deref for &mut T {
type Target = T;
fn deref(&self) -> &T {
loop {}
}
}
2021-06-16 07:30:29 +00:00
// region:deref_mut
#[lang = "deref_mut"]
pub trait DerefMut: Deref {
fn deref_mut(&mut self) -> &mut Self::Target;
}
// endregion:deref_mut
}
2021-06-18 19:10:29 +00:00
pub use self::deref::{
Deref,
DerefMut, // :deref_mut
};
// endregion:deref
2021-06-15 18:45:25 +00:00
// region:drop
#[lang = "drop"]
pub trait Drop {
fn drop(&mut self);
}
// endregion:drop
2021-06-18 19:37:03 +00:00
// region:index
mod index {
#[lang = "index"]
pub trait Index<Idx: ?Sized> {
type Output: ?Sized;
fn index(&self, index: Idx) -> &Self::Output;
}
#[lang = "index_mut"]
pub trait IndexMut<Idx: ?Sized>: Index<Idx> {
fn index_mut(&mut self, index: Idx) -> &mut Self::Output;
}
// region:slice
impl<T, I> Index<I> for [T]
where
I: SliceIndex<[T]>,
{
type Output = I::Output;
2023-09-24 20:15:36 +00:00
fn index(&self, _index: I) -> &I::Output {
2021-06-18 19:37:03 +00:00
loop {}
}
}
impl<T, I> IndexMut<I> for [T]
where
I: SliceIndex<[T]>,
{
2023-09-24 20:15:36 +00:00
fn index_mut(&mut self, _index: I) -> &mut I::Output {
2021-06-18 19:37:03 +00:00
loop {}
}
}
2023-01-31 16:53:38 +00:00
impl<T, I, const N: usize> Index<I> for [T; N]
where
I: SliceIndex<[T]>,
{
type Output = I::Output;
2023-09-24 20:15:36 +00:00
fn index(&self, _index: I) -> &I::Output {
2023-01-31 16:53:38 +00:00
loop {}
}
}
impl<T, I, const N: usize> IndexMut<I> for [T; N]
where
I: SliceIndex<[T]>,
{
2023-09-24 20:15:36 +00:00
fn index_mut(&mut self, _index: I) -> &mut I::Output {
2023-01-31 16:53:38 +00:00
loop {}
}
}
2021-06-18 19:37:03 +00:00
pub unsafe trait SliceIndex<T: ?Sized> {
type Output: ?Sized;
}
unsafe impl<T> SliceIndex<[T]> for usize {
type Output = T;
}
// endregion:slice
}
pub use self::index::{Index, IndexMut};
// endregion:index
2021-06-15 19:38:21 +00:00
// region:range
2021-06-15 18:45:25 +00:00
mod range {
#[lang = "RangeFull"]
pub struct RangeFull;
#[lang = "Range"]
pub struct Range<Idx> {
pub start: Idx,
pub end: Idx,
}
#[lang = "RangeFrom"]
pub struct RangeFrom<Idx> {
pub start: Idx,
}
#[lang = "RangeTo"]
pub struct RangeTo<Idx> {
pub end: Idx,
}
#[lang = "RangeInclusive"]
pub struct RangeInclusive<Idx> {
pub(crate) start: Idx,
pub(crate) end: Idx,
pub(crate) exhausted: bool,
}
#[lang = "RangeToInclusive"]
pub struct RangeToInclusive<Idx> {
pub end: Idx,
}
}
pub use self::range::{Range, RangeFrom, RangeFull, RangeTo};
pub use self::range::{RangeInclusive, RangeToInclusive};
2021-06-15 19:38:21 +00:00
// endregion:range
2021-06-16 07:48:07 +00:00
// region:fn
mod function {
use crate::marker::Tuple;
2021-06-16 07:48:07 +00:00
#[lang = "fn"]
#[fundamental]
pub trait Fn<Args: Tuple>: FnMut<Args> {
extern "rust-call" fn call(&self, args: Args) -> Self::Output;
}
2021-06-16 07:48:07 +00:00
#[lang = "fn_mut"]
#[fundamental]
pub trait FnMut<Args: Tuple>: FnOnce<Args> {
extern "rust-call" fn call_mut(&mut self, args: Args) -> Self::Output;
}
2021-06-16 07:48:07 +00:00
#[lang = "fn_once"]
#[fundamental]
pub trait FnOnce<Args: Tuple> {
2021-06-16 07:48:07 +00:00
#[lang = "fn_once_output"]
type Output;
extern "rust-call" fn call_once(self, args: Args) -> Self::Output;
2021-06-16 07:48:07 +00:00
}
2023-03-17 10:32:55 +00:00
mod impls {
use crate::marker::Tuple;
#[stable(feature = "rust1", since = "1.0.0")]
#[rustc_const_unstable(feature = "const_fn_trait_ref_impls", issue = "101803")]
impl<A: Tuple, F: ?Sized> const Fn<A> for &F
where
F: ~const Fn<A>,
{
extern "rust-call" fn call(&self, args: A) -> F::Output {
(**self).call(args)
}
}
#[stable(feature = "rust1", since = "1.0.0")]
#[rustc_const_unstable(feature = "const_fn_trait_ref_impls", issue = "101803")]
impl<A: Tuple, F: ?Sized> const FnMut<A> for &F
where
F: ~const Fn<A>,
{
extern "rust-call" fn call_mut(&mut self, args: A) -> F::Output {
(**self).call(args)
}
}
#[stable(feature = "rust1", since = "1.0.0")]
#[rustc_const_unstable(feature = "const_fn_trait_ref_impls", issue = "101803")]
impl<A: Tuple, F: ?Sized> const FnOnce<A> for &F
where
F: ~const Fn<A>,
{
type Output = F::Output;
extern "rust-call" fn call_once(self, args: A) -> F::Output {
(*self).call(args)
}
}
#[stable(feature = "rust1", since = "1.0.0")]
#[rustc_const_unstable(feature = "const_fn_trait_ref_impls", issue = "101803")]
impl<A: Tuple, F: ?Sized> const FnMut<A> for &mut F
where
F: ~const FnMut<A>,
{
extern "rust-call" fn call_mut(&mut self, args: A) -> F::Output {
(*self).call_mut(args)
}
}
#[stable(feature = "rust1", since = "1.0.0")]
#[rustc_const_unstable(feature = "const_fn_trait_ref_impls", issue = "101803")]
impl<A: Tuple, F: ?Sized> const FnOnce<A> for &mut F
where
F: ~const FnMut<A>,
{
type Output = F::Output;
extern "rust-call" fn call_once(self, args: A) -> F::Output {
(*self).call_mut(args)
}
}
}
2021-06-16 07:48:07 +00:00
}
pub use self::function::{Fn, FnMut, FnOnce};
// endregion:fn
// region:try
mod try_ {
2023-03-08 17:28:52 +00:00
use super::super::convert::Infallible;
pub enum ControlFlow<B, C = ()> {
2023-03-08 17:28:52 +00:00
#[lang = "Continue"]
Continue(C),
2023-03-08 17:28:52 +00:00
#[lang = "Break"]
Break(B),
}
2023-03-08 17:28:52 +00:00
pub trait FromResidual<R = <Self as Try>::Residual> {
#[lang = "from_residual"]
fn from_residual(residual: R) -> Self;
}
#[lang = "Try"]
pub trait Try: FromResidual<Self::Residual> {
type Output;
type Residual;
#[lang = "from_output"]
fn from_output(output: Self::Output) -> Self;
#[lang = "branch"]
fn branch(self) -> ControlFlow<Self::Residual, Self::Output>;
}
impl<B, C> Try for ControlFlow<B, C> {
type Output = C;
2023-03-08 17:28:52 +00:00
type Residual = ControlFlow<B, Infallible>;
2023-04-18 14:08:38 +00:00
fn from_output(output: Self::Output) -> Self {
ControlFlow::Continue(output)
}
fn branch(self) -> ControlFlow<Self::Residual, Self::Output> {
match self {
ControlFlow::Continue(x) => ControlFlow::Continue(x),
ControlFlow::Break(x) => ControlFlow::Break(ControlFlow::Break(x)),
}
}
}
impl<B, C> FromResidual for ControlFlow<B, C> {
2023-04-18 14:08:38 +00:00
fn from_residual(residual: ControlFlow<B, Infallible>) -> Self {
match residual {
ControlFlow::Break(b) => ControlFlow::Break(b),
ControlFlow::Continue(_) => loop {},
}
}
2023-03-08 17:28:52 +00:00
}
// region:option
impl<T> Try for Option<T> {
type Output = T;
type Residual = Option<Infallible>;
fn from_output(output: Self::Output) -> Self {
Some(output)
}
fn branch(self) -> ControlFlow<Self::Residual, Self::Output> {
match self {
Some(x) => ControlFlow::Continue(x),
None => ControlFlow::Break(None),
}
}
}
impl<T> FromResidual for Option<T> {
fn from_residual(x: Option<Infallible>) -> Self {
match x {
None => None,
2023-04-18 14:08:38 +00:00
Some(_) => loop {},
2023-03-08 17:28:52 +00:00
}
}
}
// endregion:option
// region:result
// region:from
use super::super::convert::From;
impl<T, E> Try for Result<T, E> {
type Output = T;
type Residual = Result<Infallible, E>;
fn from_output(output: Self::Output) -> Self {
Ok(output)
}
fn branch(self) -> ControlFlow<Self::Residual, Self::Output> {
match self {
Ok(v) => ControlFlow::Continue(v),
Err(e) => ControlFlow::Break(Err(e)),
}
}
}
impl<T, E, F: From<E>> FromResidual<Result<Infallible, E>> for Result<T, F> {
fn from_residual(residual: Result<Infallible, E>) -> Self {
match residual {
Err(e) => Err(From::from(e)),
2023-04-18 14:08:38 +00:00
Ok(_) => loop {},
2023-03-08 17:28:52 +00:00
}
}
}
2023-03-08 17:28:52 +00:00
// endregion:from
// endregion:result
}
pub use self::try_::{ControlFlow, FromResidual, Try};
// endregion:try
// region:add
#[lang = "add"]
pub trait Add<Rhs = Self> {
type Output;
fn add(self, rhs: Rhs) -> Self::Output;
}
#[lang = "add_assign"]
#[const_trait]
pub trait AddAssign<Rhs = Self> {
fn add_assign(&mut self, rhs: Rhs);
}
2023-06-03 21:33:32 +00:00
// region:builtin_impls
macro_rules! add_impl {
($($t:ty)*) => ($(
impl const Add for $t {
type Output = $t;
fn add(self, other: $t) -> $t { self + other }
}
)*)
}
add_impl! { usize u8 u16 u32 u64 u128 isize i8 i16 i32 i64 i128 f32 f64 }
// endregion:builtin_impls
// endregion:add
// region:coroutine
mod coroutine {
use crate::pin::Pin;
#[lang = "coroutine"]
pub trait Coroutine<R = ()> {
type Yield;
#[lang = "coroutine_return"]
type Return;
fn resume(self: Pin<&mut Self>, arg: R) -> CoroutineState<Self::Yield, Self::Return>;
}
#[lang = "coroutine_state"]
pub enum CoroutineState<Y, R> {
Yielded(Y),
Complete(R),
}
}
pub use self::coroutine::{Coroutine, CoroutineState};
// endregion:coroutine
}
// region:eq
pub mod cmp {
#[lang = "eq"]
pub trait PartialEq<Rhs: ?Sized = Self> {
fn eq(&self, other: &Rhs) -> bool;
2022-07-20 04:26:50 +00:00
fn ne(&self, other: &Rhs) -> bool {
!self.eq(other)
}
}
pub trait Eq: PartialEq<Self> {}
// region:derive
#[rustc_builtin_macro]
pub macro PartialEq($item:item) {}
#[rustc_builtin_macro]
pub macro Eq($item:item) {}
// endregion:derive
// region:ord
#[lang = "partial_ord"]
pub trait PartialOrd<Rhs: ?Sized = Self>: PartialEq<Rhs> {
fn partial_cmp(&self, other: &Rhs) -> Option<Ordering>;
}
pub trait Ord: Eq + PartialOrd<Self> {
fn cmp(&self, other: &Self) -> Ordering;
}
pub enum Ordering {
Less = -1,
Equal = 0,
Greater = 1,
}
// region:derive
#[rustc_builtin_macro]
pub macro PartialOrd($item:item) {}
#[rustc_builtin_macro]
pub macro Ord($item:item) {}
// endregion:derive
// endregion:ord
}
// endregion:eq
2021-08-08 16:58:42 +00:00
// region:fmt
pub mod fmt {
pub struct Error;
pub type Result = Result<(), Error>;
pub struct Formatter<'a>;
2023-05-12 09:06:57 +00:00
pub struct DebugTuple;
pub struct DebugStruct;
impl Formatter<'_> {
2023-09-24 20:15:36 +00:00
pub fn debug_tuple(&mut self, _name: &str) -> DebugTuple {
2023-05-12 09:06:57 +00:00
DebugTuple
}
2023-09-24 20:15:36 +00:00
pub fn debug_struct(&mut self, _name: &str) -> DebugStruct {
2023-05-12 09:06:57 +00:00
DebugStruct
}
}
impl DebugTuple {
2023-09-24 20:15:36 +00:00
pub fn field(&mut self, _value: &dyn Debug) -> &mut Self {
2023-05-12 09:06:57 +00:00
self
}
pub fn finish(&mut self) -> Result {
Ok(())
}
}
impl DebugStruct {
2023-09-24 20:15:36 +00:00
pub fn field(&mut self, _name: &str, _value: &dyn Debug) -> &mut Self {
2023-05-12 09:06:57 +00:00
self
}
pub fn finish(&mut self) -> Result {
Ok(())
}
}
2021-08-08 16:58:42 +00:00
pub trait Debug {
fn fmt(&self, f: &mut Formatter<'_>) -> Result;
}
pub trait Display {
fn fmt(&self, f: &mut Formatter<'_>) -> Result;
}
2023-09-06 13:21:41 +00:00
mod rt {
2024-03-26 07:34:05 +00:00
use super::*;
2023-09-06 13:21:41 +00:00
extern "C" {
type Opaque;
}
2024-04-19 11:18:30 +00:00
#[derive(Copy, Clone)]
2023-09-06 13:21:41 +00:00
#[lang = "format_argument"]
pub struct Argument<'a> {
value: &'a Opaque,
formatter: fn(&Opaque, &mut Formatter<'_>) -> Result,
}
impl<'a> Argument<'a> {
pub fn new<'b, T>(x: &'b T, f: fn(&T, &mut Formatter<'_>) -> Result) -> Argument<'b> {
use crate::mem::transmute;
unsafe { Argument { formatter: transmute(f), value: transmute(x) } }
}
2024-02-01 09:02:19 +00:00
2024-03-26 07:34:05 +00:00
pub fn new_display<'b, T: crate::fmt::Display>(x: &'b T) -> Argument<'_> {
Self::new(x, crate::fmt::Display::fmt)
2024-02-01 09:02:19 +00:00
}
2023-09-06 13:21:41 +00:00
}
#[lang = "format_alignment"]
pub enum Alignment {
Left,
Right,
Center,
Unknown,
}
2023-09-06 13:21:41 +00:00
#[lang = "format_count"]
pub enum Count {
Is(usize),
Param(usize),
Implied,
}
#[lang = "format_placeholder"]
pub struct Placeholder {
pub position: usize,
pub fill: char,
pub align: Alignment,
pub flags: u32,
pub precision: Count,
pub width: Count,
}
impl Placeholder {
pub const fn new(
position: usize,
fill: char,
align: Alignment,
flags: u32,
precision: Count,
width: Count,
2024-03-26 07:34:05 +00:00
) -> Self {
Placeholder { position, fill, align, flags, precision, width }
}
2023-09-06 13:21:41 +00:00
}
#[lang = "format_unsafe_arg"]
pub struct UnsafeArg {
_private: (),
}
impl UnsafeArg {
2024-03-25 16:58:15 +00:00
pub unsafe fn new() -> Self {
UnsafeArg { _private: () }
}
}
}
2024-04-19 11:18:30 +00:00
#[derive(Copy, Clone)]
#[lang = "format_arguments"]
pub struct Arguments<'a> {
pieces: &'a [&'static str],
2023-09-06 13:21:41 +00:00
fmt: Option<&'a [rt::Placeholder]>,
args: &'a [rt::Argument<'a>],
}
impl<'a> Arguments<'a> {
pub const fn new_v1(pieces: &'a [&'static str], args: &'a [Argument<'a>]) -> Arguments<'a> {
2023-09-06 13:21:41 +00:00
Arguments { pieces, fmt: None, args }
}
pub const fn new_const(pieces: &'a [&'static str]) -> Arguments<'a> {
Arguments { pieces, fmt: None, args: &[] }
}
2023-09-06 13:21:41 +00:00
pub fn new_v1_formatted(
pieces: &'a [&'static str],
args: &'a [rt::Argument<'a>],
fmt: &'a [rt::Placeholder],
_unsafe_arg: rt::UnsafeArg,
) -> Arguments<'a> {
Arguments { pieces, fmt: Some(fmt), args }
}
2024-03-26 07:34:05 +00:00
pub const fn as_str(&self) -> Option<&'static str> {
match (self.pieces, self.args) {
([], []) => Some(""),
([s], []) => Some(s),
_ => None,
}
}
}
// region:derive
#[rustc_builtin_macro]
pub macro Debug($item:item) {}
// endregion:derive
2023-05-12 09:06:57 +00:00
// region:builtin_impls
macro_rules! impl_debug {
($($t:ty)*) => {
$(
impl const Debug for $t {
2023-09-24 20:15:36 +00:00
fn fmt(&self, _f: &mut Formatter<'_>) -> Result {
2023-05-12 09:06:57 +00:00
Ok(())
}
}
)*
}
}
impl_debug! {
usize u8 u16 u32 u64 u128
isize i8 i16 i32 i64 i128
f32 f64
bool char
}
impl<T: Debug> Debug for [T] {
2023-09-24 20:15:36 +00:00
fn fmt(&self, _f: &mut Formatter<'_>) -> Result {
2023-05-12 09:06:57 +00:00
Ok(())
}
}
impl<T: Debug + ?Sized> Debug for &T {
fn fmt(&self, f: &mut Formatter<'_>) -> Result {
(&**self).fmt(f)
}
}
// endregion:builtin_impls
2021-08-08 16:58:42 +00:00
}
// endregion:fmt
// region:slice
pub mod slice {
#[lang = "slice"]
impl<T> [T] {
2023-02-03 11:16:25 +00:00
#[lang = "slice_len_fn"]
2021-06-15 18:45:25 +00:00
pub fn len(&self) -> usize {
loop {}
}
}
}
// endregion:slice
2021-06-15 19:59:51 +00:00
// region:option
pub mod option {
pub enum Option<T> {
#[lang = "None"]
None,
#[lang = "Some"]
Some(T),
}
// region:copy
impl<T: Copy> Copy for Option<T> {}
// endregion:copy
impl<T> Option<T> {
pub const fn unwrap(self) -> T {
match self {
Some(val) => val,
None => panic!("called `Option::unwrap()` on a `None` value"),
}
}
pub const fn as_ref(&self) -> Option<&T> {
match self {
Some(x) => Some(x),
None => None,
}
}
2023-09-24 20:15:36 +00:00
pub fn and<U>(self, _optb: Option<U>) -> Option<U> {
loop {}
}
pub fn unwrap_or(self, default: T) -> T {
2023-03-14 19:31:46 +00:00
match self {
Some(val) => val,
None => default,
}
}
2023-04-28 17:14:30 +00:00
// region:result
pub const fn ok_or<E>(self, err: E) -> Result<T, E> {
match self {
Some(v) => Ok(v),
None => Err(err),
}
}
// endregion:result
// region:fn
2023-09-24 20:15:36 +00:00
pub fn and_then<U, F>(self, _f: F) -> Option<U>
where
F: FnOnce(T) -> Option<U>,
{
loop {}
}
2023-09-24 20:15:36 +00:00
pub fn unwrap_or_else<F>(self, _f: F) -> T
where
F: FnOnce() -> T,
{
loop {}
}
2023-09-24 20:15:36 +00:00
pub fn map_or<U, F>(self, _default: U, _f: F) -> U
where
F: FnOnce(T) -> U,
{
loop {}
}
2023-09-24 20:15:36 +00:00
pub fn map_or_else<U, D, F>(self, _default: D, _f: F) -> U
where
D: FnOnce() -> U,
F: FnOnce(T) -> U,
{
loop {}
}
// endregion:fn
}
2021-06-15 19:59:51 +00:00
}
// endregion:option
2021-06-15 20:07:25 +00:00
// region:result
pub mod result {
pub enum Result<T, E> {
#[lang = "Ok"]
Ok(T),
#[lang = "Err"]
Err(E),
}
}
// endregion:result
2021-06-15 19:49:00 +00:00
// region:pin
pub mod pin {
#[lang = "pin"]
#[fundamental]
pub struct Pin<P> {
pointer: P,
}
impl<P> Pin<P> {
2024-03-26 07:34:05 +00:00
pub fn new(pointer: P) -> Pin<P> {
Pin { pointer }
}
}
// region:deref
impl<P: crate::ops::Deref> crate::ops::Deref for Pin<P> {
type Target = P::Target;
fn deref(&self) -> &P::Target {
loop {}
}
}
// endregion:deref
2021-06-15 19:49:00 +00:00
}
// endregion:pin
// region:future
pub mod future {
2021-06-15 19:59:51 +00:00
use crate::{
pin::Pin,
task::{Context, Poll},
};
2021-06-15 19:49:00 +00:00
#[doc(notable_trait)]
2021-06-15 19:49:00 +00:00
#[lang = "future_trait"]
pub trait Future {
type Output;
#[lang = "poll"]
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>;
}
2022-08-09 00:20:45 +00:00
pub trait IntoFuture {
type Output;
type IntoFuture: Future<Output = Self::Output>;
#[lang = "into_future"]
fn into_future(self) -> Self::IntoFuture;
}
impl<F: Future> IntoFuture for F {
type Output = F::Output;
type IntoFuture = F;
fn into_future(self) -> F {
self
}
}
2021-06-15 19:49:00 +00:00
}
pub mod task {
pub enum Poll<T> {
#[lang = "Ready"]
Ready(T),
#[lang = "Pending"]
Pending,
}
pub struct Context<'a> {
waker: &'a (),
}
}
// endregion:future
2021-06-16 19:48:48 +00:00
// region:iterator
pub mod iter {
// region:iterators
2021-06-16 20:27:04 +00:00
mod adapters {
pub struct Take<I> {
iter: I,
n: usize,
}
impl<I> Iterator for Take<I>
where
I: Iterator,
{
type Item = <I as Iterator>::Item;
fn next(&mut self) -> Option<<I as Iterator>::Item> {
loop {}
}
}
2021-06-18 20:48:18 +00:00
pub struct FilterMap<I, F> {
iter: I,
f: F,
}
impl<B, I: Iterator, F> Iterator for FilterMap<I, F>
where
F: FnMut(I::Item) -> Option<B>,
{
type Item = B;
#[inline]
fn next(&mut self) -> Option<B> {
loop {}
}
}
2021-06-16 20:27:04 +00:00
}
pub use self::adapters::{FilterMap, Take};
2021-06-16 20:27:04 +00:00
mod sources {
mod repeat {
2023-09-24 20:15:36 +00:00
pub fn repeat<T>(_elt: T) -> Repeat<T> {
loop {}
}
pub struct Repeat<A> {
element: A,
}
impl<A> Iterator for Repeat<A> {
type Item = A;
fn next(&mut self) -> Option<A> {
loop {}
}
}
}
pub use self::repeat::{repeat, Repeat};
}
pub use self::sources::{repeat, Repeat};
// endregion:iterators
2021-06-16 19:48:48 +00:00
mod traits {
mod iterator {
#[doc(notable_trait)]
2021-06-16 19:48:48 +00:00
pub trait Iterator {
type Item;
#[lang = "next"]
fn next(&mut self) -> Option<Self::Item>;
fn nth(&mut self, n: usize) -> Option<Self::Item> {
loop {}
}
fn by_ref(&mut self) -> &mut Self
where
Self: Sized,
{
self
}
// region:iterators
fn take(self, n: usize) -> crate::iter::Take<Self> {
loop {}
}
2023-09-24 20:15:36 +00:00
fn filter_map<B, F>(self, _f: F) -> crate::iter::FilterMap<Self, F>
2021-06-18 20:48:18 +00:00
where
Self: Sized,
F: FnMut(Self::Item) -> Option<B>,
{
loop {}
}
// endregion:iterators
}
impl<I: Iterator + ?Sized> Iterator for &mut I {
type Item = I::Item;
fn next(&mut self) -> Option<I::Item> {
(**self).next()
}
2021-06-16 19:48:48 +00:00
}
}
2021-06-16 20:27:04 +00:00
pub use self::iterator::Iterator;
2021-06-16 19:48:48 +00:00
mod collect {
pub trait IntoIterator {
type Item;
type IntoIter: Iterator<Item = Self::Item>;
#[lang = "into_iter"]
fn into_iter(self) -> Self::IntoIter;
}
impl<I: Iterator> IntoIterator for I {
type Item = I::Item;
type IntoIter = I;
fn into_iter(self) -> I {
self
}
}
2023-04-11 01:02:11 +00:00
struct IndexRange {
start: usize,
end: usize,
}
pub struct IntoIter<T, const N: usize> {
data: [T; N],
range: IndexRange,
}
2023-03-02 07:48:50 +00:00
impl<T, const N: usize> IntoIterator for [T; N] {
type Item = T;
type IntoIter = IntoIter<T, N>;
fn into_iter(self) -> I {
2023-04-18 14:08:38 +00:00
IntoIter { data: self, range: IndexRange { start: 0, end: loop {} } }
2023-03-02 07:48:50 +00:00
}
}
impl<T, const N: usize> Iterator for IntoIter<T, N> {
type Item = T;
fn next(&mut self) -> Option<T> {
loop {}
}
}
2021-06-16 19:48:48 +00:00
}
pub use self::collect::IntoIterator;
}
pub use self::traits::{IntoIterator, Iterator};
}
// endregion:iterator
2023-04-18 14:08:38 +00:00
// region:panic
mod panic {
pub macro panic_2021 {
() => ({
const fn panic_cold_explicit() -> ! {
$crate::panicking::panic_explicit()
}
panic_cold_explicit();
}),
// Special-case the single-argument case for const_panic.
("{}", $arg:expr $(,)?) => ({
#[rustc_const_panic_str] // enforce a &&str argument in const-check and hook this by const-eval
#[rustc_do_not_const_check] // hooked by const-eval
const fn panic_cold_display<T: $crate::fmt::Display>(arg: &T) -> ! {
$crate::panicking::panic_display(arg)
}
panic_cold_display(&$arg);
}),
($($t:tt)+) => ({
// Semicolon to prevent temporaries inside the formatting machinery from
// being considered alive in the caller after the panic_fmt call.
$crate::panicking::panic_fmt($crate::const_format_args!($($t)+));
}),
}
}
mod panicking {
#[rustc_const_panic_str] // enforce a &&str argument in const-check and hook this by const-eval
2024-03-26 07:34:05 +00:00
pub const fn panic_display<T: crate::fmt::Display>(x: &T) -> ! {
panic_fmt(crate::format_args!("{}", *x));
}
// This function is used instead of panic_fmt in const eval.
#[lang = "const_panic_fmt"]
pub const fn const_panic_fmt(fmt: crate::fmt::Arguments<'_>) -> ! {
if let Some(msg) = fmt.as_str() {
// The panic_display function is hooked by const eval.
panic_display(&msg);
} else {
loop {}
}
}
#[lang = "panic_fmt"] // needed for const-evaluated panics
2024-03-26 07:34:05 +00:00
pub const fn panic_fmt(fmt: crate::fmt::Arguments<'_>) -> ! {
loop {}
2023-04-18 14:08:38 +00:00
}
#[lang = "panic"]
pub const fn panic(expr: &'static str) -> ! {
panic_fmt(crate::fmt::Arguments::new_const(&[expr]))
}
2023-04-18 14:08:38 +00:00
}
// endregion:panic
2024-04-19 11:18:30 +00:00
#[macro_use]
mod macros {
2023-04-18 14:08:38 +00:00
// region:panic
#[macro_export]
2023-12-02 15:50:21 +00:00
#[rustc_builtin_macro(core_panic)]
2023-04-18 14:08:38 +00:00
macro_rules! panic {
($($arg:tt)*) => {
/* compiler built-in */
};
}
// endregion:panic
// region:asm
#[macro_export]
#[rustc_builtin_macro]
macro_rules! asm {
($($arg:tt)*) => {
/* compiler built-in */
};
}
// endregion:asm
// region:assert
#[macro_export]
#[rustc_builtin_macro]
#[allow_internal_unstable(core_panic, edition_panic, generic_assert_internals)]
macro_rules! assert {
($($arg:tt)*) => {
/* compiler built-in */
};
}
// endregion:assert
// region:fmt
#[allow_internal_unstable(fmt_internals, const_fmt_arguments_new)]
#[macro_export]
#[rustc_builtin_macro]
macro_rules! const_format_args {
($fmt:expr) => {{ /* compiler built-in */ }};
($fmt:expr, $($args:tt)*) => {{ /* compiler built-in */ }};
}
#[allow_internal_unstable(fmt_internals)]
#[macro_export]
#[rustc_builtin_macro]
macro_rules! format_args {
($fmt:expr) => {{ /* compiler built-in */ }};
($fmt:expr, $($args:tt)*) => {{ /* compiler built-in */ }};
}
#[allow_internal_unstable(fmt_internals)]
#[macro_export]
#[rustc_builtin_macro]
macro_rules! format_args_nl {
($fmt:expr) => {{ /* compiler built-in */ }};
($fmt:expr, $($args:tt)*) => {{ /* compiler built-in */ }};
}
#[macro_export]
macro_rules! print {
($($arg:tt)*) => {{
$crate::io::_print($crate::format_args!($($arg)*));
}};
}
// endregion:fmt
2024-02-01 09:02:19 +00:00
// region:todo
#[macro_export]
#[allow_internal_unstable(core_panic)]
macro_rules! todo {
() => {
$crate::panicking::panic("not yet implemented")
};
($($arg:tt)+) => {
$crate::panic!("not yet implemented: {}", $crate::format_args!($($arg)+))
};
}
// endregion:todo
// region:unimplemented
#[macro_export]
#[allow_internal_unstable(core_panic)]
macro_rules! unimplemented {
() => {
$crate::panicking::panic("not implemented")
};
($($arg:tt)+) => {
$crate::panic!("not implemented: {}", $crate::format_args!($($arg)+))
};
}
// endregion:unimplemented
2023-04-18 14:08:38 +00:00
// region:derive
pub(crate) mod builtin {
#[rustc_builtin_macro]
pub macro derive($item:item) {
/* compiler built-in */
}
2023-06-29 17:28:35 +00:00
#[rustc_builtin_macro]
pub macro derive_const($item:item) {
/* compiler built-in */
}
}
2023-04-18 14:08:38 +00:00
// endregion:derive
2023-06-04 08:02:11 +00:00
// region:include
#[rustc_builtin_macro]
#[macro_export]
macro_rules! include {
($file:expr $(,)?) => {{ /* compiler built-in */ }};
}
// endregion:include
2023-12-02 15:50:21 +00:00
// region:concat
#[rustc_builtin_macro]
#[macro_export]
macro_rules! concat {}
// endregion:concat
2024-01-08 09:37:09 +00:00
// region:env
#[rustc_builtin_macro]
#[macro_export]
macro_rules! env {}
#[rustc_builtin_macro]
#[macro_export]
macro_rules! option_env {}
// endregion:env
}
2022-10-27 19:58:34 +00:00
// region:non_zero
pub mod num {
#[repr(transparent)]
#[rustc_layout_scalar_valid_range_start(1)]
#[rustc_nonnull_optimization_guaranteed]
pub struct NonZeroU8(u8);
}
// endregion:non_zero
2021-08-10 11:03:12 +00:00
// region:bool_impl
#[lang = "bool"]
impl bool {
pub fn then<T, F: FnOnce() -> T>(self, f: F) -> Option<T> {
if self {
Some(f())
} else {
None
}
}
}
// endregion:bool_impl
2023-06-05 11:27:19 +00:00
// region:int_impl
macro_rules! impl_int {
($($t:ty)*) => {
$(
impl $t {
pub const fn from_ne_bytes(bytes: [u8; mem::size_of::<Self>()]) -> Self {
unsafe { mem::transmute(bytes) }
}
}
)*
}
}
impl_int! {
usize u8 u16 u32 u64 u128
isize i8 i16 i32 i64 i128
}
// endregion:int_impl
// region:error
pub mod error {
#[rustc_has_incoherent_inherent_impls]
pub trait Error: crate::fmt::Debug + crate::fmt::Display {
fn source(&self) -> Option<&(dyn Error + 'static)> {
None
}
}
}
// endregion:error
pub mod prelude {
pub mod v1 {
2021-06-15 20:07:25 +00:00
pub use crate::{
2023-06-29 17:28:35 +00:00
clone::Clone, // :clone
cmp::{Eq, PartialEq}, // :eq
cmp::{Ord, PartialOrd}, // :ord
convert::AsRef, // :as_ref
convert::{From, Into}, // :from
default::Default, // :default
iter::{IntoIterator, Iterator}, // :iterator
macros::builtin::{derive, derive_const}, // :derive
marker::Copy, // :copy
marker::Send, // :send
marker::Sized, // :sized
marker::Sync, // :sync
mem::drop, // :drop
ops::Drop, // :drop
ops::{Fn, FnMut, FnOnce}, // :fn
option::Option::{self, None, Some}, // :option
panic, // :panic
result::Result::{self, Err, Ok}, // :result
2021-06-15 20:07:25 +00:00
};
}
pub mod rust_2015 {
pub use super::v1::*;
}
pub mod rust_2018 {
pub use super::v1::*;
}
pub mod rust_2021 {
pub use super::v1::*;
}
}
#[prelude_import]
#[allow(unused)]
use prelude::v1::*;