Rollup merge of #67637 - Mark-Simulacrum:primitive-mod, r=dtolnay
Add primitive module to libcore This re-exports the primitive types from libcore at `core::primitive` to allow macro authors to have a reliable location to use them from. Fixes #44865
This commit is contained in:
commit
0860f5aebd
@ -267,6 +267,9 @@ mod bool;
|
|||||||
mod tuple;
|
mod tuple;
|
||||||
mod unit;
|
mod unit;
|
||||||
|
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub mod primitive;
|
||||||
|
|
||||||
// Pull in the `core_arch` crate directly into libcore. The contents of
|
// Pull in the `core_arch` crate directly into libcore. The contents of
|
||||||
// `core_arch` are in a different repository: rust-lang/stdarch.
|
// `core_arch` are in a different repository: rust-lang/stdarch.
|
||||||
//
|
//
|
||||||
|
67
src/libcore/primitive.rs
Normal file
67
src/libcore/primitive.rs
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
//! This module reexports the primitive types to allow usage that is not
|
||||||
|
//! possibly shadowed by other declared types.
|
||||||
|
//!
|
||||||
|
//! This is normally only useful in macro generated code.
|
||||||
|
//!
|
||||||
|
//! An example of this is when generating a new struct and an impl for it:
|
||||||
|
//!
|
||||||
|
//! ```rust,compile_fail
|
||||||
|
//! pub struct bool;
|
||||||
|
//!
|
||||||
|
//! impl QueryId for bool {
|
||||||
|
//! const SOME_PROPERTY: bool = true;
|
||||||
|
//! }
|
||||||
|
//!
|
||||||
|
//! # trait QueryId { const SOME_PROPERTY: core::primitive::bool; }
|
||||||
|
//! ```
|
||||||
|
//!
|
||||||
|
//! Note that the `SOME_PROPERTY` associated constant would not compile, as its
|
||||||
|
//! type `bool` refers to the struct, rather than to the primitive bool type.
|
||||||
|
//!
|
||||||
|
//! A correct implementation could look like:
|
||||||
|
//!
|
||||||
|
//! ```rust
|
||||||
|
//! # #[allow(non_camel_case_types)]
|
||||||
|
//! pub struct bool;
|
||||||
|
//!
|
||||||
|
//! impl QueryId for bool {
|
||||||
|
//! const SOME_PROPERTY: core::primitive::bool = true;
|
||||||
|
//! }
|
||||||
|
//!
|
||||||
|
//! # trait QueryId { const SOME_PROPERTY: core::primitive::bool; }
|
||||||
|
//! ```
|
||||||
|
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use bool;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use char;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use f32;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use f64;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use i128;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use i16;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use i32;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use i64;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use i8;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use isize;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use str;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use u128;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use u16;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use u32;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use u64;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use u8;
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use usize;
|
@ -233,12 +233,12 @@
|
|||||||
#![feature(allocator_internals)]
|
#![feature(allocator_internals)]
|
||||||
#![feature(allow_internal_unsafe)]
|
#![feature(allow_internal_unsafe)]
|
||||||
#![feature(allow_internal_unstable)]
|
#![feature(allow_internal_unstable)]
|
||||||
#![feature(atomic_mut_ptr)]
|
|
||||||
#![feature(arbitrary_self_types)]
|
#![feature(arbitrary_self_types)]
|
||||||
#![feature(array_error_internals)]
|
#![feature(array_error_internals)]
|
||||||
#![feature(asm)]
|
#![feature(asm)]
|
||||||
#![feature(assoc_int_consts)]
|
#![feature(assoc_int_consts)]
|
||||||
#![feature(associated_type_bounds)]
|
#![feature(associated_type_bounds)]
|
||||||
|
#![feature(atomic_mut_ptr)]
|
||||||
#![feature(box_syntax)]
|
#![feature(box_syntax)]
|
||||||
#![feature(c_variadic)]
|
#![feature(c_variadic)]
|
||||||
#![feature(cfg_target_has_atomic)]
|
#![feature(cfg_target_has_atomic)]
|
||||||
@ -551,6 +551,9 @@ pub use core::{
|
|||||||
trace_macros,
|
trace_macros,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#[stable(feature = "core_primitive", since = "1.43.0")]
|
||||||
|
pub use core::primitive;
|
||||||
|
|
||||||
// Include a number of private modules that exist solely to provide
|
// Include a number of private modules that exist solely to provide
|
||||||
// the rustdoc documentation for primitive types. Using `include!`
|
// the rustdoc documentation for primitive types. Using `include!`
|
||||||
// because rustdoc only looks for these modules at the crate level.
|
// because rustdoc only looks for these modules at the crate level.
|
||||||
|
@ -9,6 +9,11 @@ error[E0412]: cannot find type `u8` in the crate root
|
|||||||
|
|
|
|
||||||
LL | let _: ::u8;
|
LL | let _: ::u8;
|
||||||
| ^^ not found in the crate root
|
| ^^ not found in the crate root
|
||||||
|
|
|
||||||
|
help: possible candidate is found in another module, you can import it into scope
|
||||||
|
|
|
||||||
|
LL | use std::primitive::u8;
|
||||||
|
|
|
||||||
|
|
||||||
error[E0061]: this function takes 0 arguments but 1 argument was supplied
|
error[E0061]: this function takes 0 arguments but 1 argument was supplied
|
||||||
--> $DIR/resolve-primitive-fallback.rs:3:5
|
--> $DIR/resolve-primitive-fallback.rs:3:5
|
||||||
|
18
src/test/ui/shadow-bool.rs
Normal file
18
src/test/ui/shadow-bool.rs
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
// check-pass
|
||||||
|
|
||||||
|
mod bar {
|
||||||
|
pub trait QueryId {
|
||||||
|
const SOME_PROPERTY: bool;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
use bar::QueryId;
|
||||||
|
|
||||||
|
#[allow(non_camel_case_types)]
|
||||||
|
pub struct bool;
|
||||||
|
|
||||||
|
impl QueryId for bool {
|
||||||
|
const SOME_PROPERTY: core::primitive::bool = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
Loading…
x
Reference in New Issue
Block a user