//! 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: //! sized: //! unsize: sized //! coerce_unsized: unsize //! slice: //! range: //! deref: sized //! deref_mut: deref //! fn: //! pin: //! future: pin //! option: //! result: //! iterator: option pub mod marker { // region:sized #[lang = "sized"] #[fundamental] #[rustc_specialization_trait] pub trait Sized {} // endregion:sized // region:unsize #[lang = "unsize"] pub trait Unsize {} // endregion:unsize } pub mod ops { // region:coerce_unsized mod unsize { use crate::marker::Unsize; #[lang = "coerce_unsized"] pub trait CoerceUnsized {} impl<'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<&'a mut U> for &'a mut T {} impl<'a, 'b: 'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<&'a U> for &'b mut T {} impl<'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<*mut U> for &'a mut T {} impl<'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<*const U> for &'a mut T {} impl<'a, 'b: 'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<&'a U> for &'b T {} impl<'a, T: ?Sized + Unsize, U: ?Sized> CoerceUnsized<*const U> for &'a T {} impl, U: ?Sized> CoerceUnsized<*mut U> for *mut T {} impl, U: ?Sized> CoerceUnsized<*const U> for *mut T {} impl, 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; } // region:deref_mut #[lang = "deref_mut"] pub trait DerefMut: Deref { fn deref_mut(&mut self) -> &mut Self::Target; } // endregion:deref_mut } pub use self::deref::Deref; pub use self::deref::DerefMut; //:deref_mut // endregion:deref // region:range mod range { #[lang = "RangeFull"] pub struct RangeFull; #[lang = "Range"] pub struct Range { pub start: Idx, pub end: Idx, } #[lang = "RangeFrom"] pub struct RangeFrom { pub start: Idx, } #[lang = "RangeTo"] pub struct RangeTo { pub end: Idx, } #[lang = "RangeInclusive"] pub struct RangeInclusive { pub(crate) start: Idx, pub(crate) end: Idx, pub(crate) exhausted: bool, } #[lang = "RangeToInclusive"] pub struct RangeToInclusive { pub end: Idx, } } pub use self::range::{Range, RangeFrom, RangeFull, RangeTo}; pub use self::range::{RangeInclusive, RangeToInclusive}; // endregion:range // region:fn mod function { #[lang = "fn"] #[fundamental] pub trait Fn: FnMut {} #[lang = "fn_mut"] #[fundamental] pub trait FnMut: FnOnce {} #[lang = "fn_once"] #[fundamental] pub trait FnOnce { #[lang = "fn_once_output"] type Output; } } pub use self::function::{Fn, FnMut, FnOnce}; // endregion:fn } // region:slice pub mod slice { #[lang = "slice"] impl [T] { pub fn len(&self) -> usize { loop {} } } } // endregion:slice // region:option pub mod option { pub enum Option { #[lang = "None"] None, #[lang = "Some"] Some(T), } } // endregion:option // region:result pub mod result { pub enum Result { #[lang = "Ok"] Ok(T), #[lang = "Err"] Err(E), } } // endregion:result // region:pin pub mod pin { #[lang = "pin"] #[fundamental] pub struct Pin

{ pointer: P, } } // endregion:pin // region:future pub mod future { use crate::{ pin::Pin, task::{Context, Poll}, }; #[lang = "future_trait"] pub trait Future { type Output; #[lang = "poll"] fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll; } } pub mod task { pub enum Poll { #[lang = "Ready"] Ready(T), #[lang = "Pending"] Pending, } pub struct Context<'a> { waker: &'a (), } } // endregion:future // region:iterator pub mod iter { mod adapters { pub struct Take { iter: I, n: usize, } impl Iterator for Take where I: Iterator, { type Item = ::Item; fn next(&mut self) -> Option<::Item> { loop {} } } } pub use self::adapters::Take; mod traits { mod iterator { use super::super::Take; pub trait Iterator { type Item; #[lang = "next"] fn next(&mut self) -> Option; fn nth(&mut self, n: usize) -> Option { loop {} } fn take(self, n: usize) -> crate::iter::Take { loop {} } } } pub use self::iterator::Iterator; mod collect { pub trait IntoIterator { type Item; type IntoIter: Iterator; #[lang = "into_iter"] fn into_iter(self) -> Self::IntoIter; } impl IntoIterator for I { type Item = I::Item; type IntoIter = I; fn into_iter(self) -> I { self } } } pub use self::collect::IntoIterator; } pub use self::traits::{IntoIterator, Iterator}; } // endregion:iterator pub mod prelude { pub mod v1 { pub use crate::{ iter::{IntoIterator, Iterator}, // :iterator marker::Sized, // :sized ops::{Fn, FnMut, FnOnce}, // :fn option::Option::{self, None, Some}, // :option result::Result::{self, Err, Ok}, // :result }; } 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::*;