1//! # The Rust Core Library
2//!
3//! The Rust Core Library is the dependency-free[^free] foundation of [The
4//! Rust Standard Library](../std/index.html). It is the portable glue
5//! between the language and its libraries, defining the intrinsic and
6//! primitive building blocks of all Rust code. It links to no
7//! upstream libraries, no system libraries, and no libc.
8//!
9//! [^free]: Strictly speaking, there are some symbols which are needed but
10//! they aren't always necessary.
11//!
12//! The core library is *minimal*: it isn't even aware of heap allocation,
13//! nor does it provide concurrency or I/O. These things require
14//! platform integration, and this library is platform-agnostic.
15//!
16//! # How to use the core library
17//!
18//! Please note that all of these details are currently not considered stable.
19//!
20// FIXME: Fill me in with more detail when the interface settles
21//! This library is built on the assumption of a few existing symbols:
22//!
23//! * `memcpy`, `memmove`, `memset`, `memcmp`, `bcmp`, `strlen` - These are core memory routines
24//! which are generated by Rust codegen backends. Additionally, this library can make explicit
25//! calls to `strlen`. Their signatures are the same as found in C, but there are extra
26//! assumptions about their semantics: For `memcpy`, `memmove`, `memset`, `memcmp`, and `bcmp`, if
27//! the `n` parameter is 0, the function is assumed to not be UB, even if the pointers are NULL or
28//! dangling. (Note that making extra assumptions about these functions is common among compilers:
29//! [clang](https://reviews.llvm.org/D86993) and [GCC](https://gcc.gnu.org/onlinedocs/gcc/Standards.html#C-Language) do the same.)
30//! These functions are often provided by the system libc, but can also be provided by the
31//! [compiler-builtins crate](https://crates.io/crates/compiler_builtins).
32//! Note that the library does not guarantee that it will always make these assumptions, so Rust
33//! user code directly calling the C functions should follow the C specification! The advice for
34//! Rust user code is to call the functions provided by this library instead (such as
35//! `ptr::copy`).
36//!
37//! * Panic handler - This function takes one argument, a `&panic::PanicInfo`. It is up to consumers of this core
38//! library to define this panic function; it is only required to never
39//! return. You should mark your implementation using `#[panic_handler]`.
40//!
41//! * `rust_eh_personality` - is used by the failure mechanisms of the
42//! compiler. This is often mapped to GCC's personality function, but crates
43//! which do not trigger a panic can be assured that this function is never
44//! called. The `lang` attribute is called `eh_personality`.
4546#![stable(feature = "core", since = "1.6.0")]
47#![doc(
48 html_playground_url = "https://play.rust-lang.org/",
49 issue_tracker_base_url = "https://github.com/rust-lang/rust/issues/",
50 test(no_crate_inject, attr(deny(warnings))),
51 test(attr(allow(dead_code, deprecated, unused_variables, unused_mut, duplicate_features)))
52)]
53#![doc(rust_logo)]
54#![doc(auto_cfg(hide(
55 no_fp_fmt_parse,
56 target_pointer_width = "16",
57 target_pointer_width = "32",
58 target_pointer_width = "64",
59 target_has_atomic = "8",
60 target_has_atomic = "16",
61 target_has_atomic = "32",
62 target_has_atomic = "64",
63 target_has_atomic = "ptr",
64 target_has_atomic_primitive_alignment = "8",
65 target_has_atomic_primitive_alignment = "16",
66 target_has_atomic_primitive_alignment = "32",
67 target_has_atomic_primitive_alignment = "64",
68 target_has_atomic_primitive_alignment = "ptr",
69 target_has_atomic_load_store = "8",
70 target_has_atomic_load_store = "16",
71 target_has_atomic_load_store = "32",
72 target_has_atomic_load_store = "64",
73 target_has_atomic_load_store = "ptr",
74)))]
75#![no_core]
76#![rustc_coherence_is_core]
77#![rustc_preserve_ub_checks]
78//
79// Lints:
80#![deny(rust_2021_incompatible_or_patterns)]
81#![deny(unsafe_op_in_unsafe_fn)]
82#![deny(fuzzy_provenance_casts)]
83#![warn(deprecated_in_future)]
84#![warn(missing_debug_implementations)]
85#![warn(missing_docs)]
86#![allow(explicit_outlives_requirements)]
87#![allow(incomplete_features)]
88#![warn(multiple_supertrait_upcastable)]
89#![allow(internal_features)]
90#![allow(unused_features)]
91#![deny(ffi_unwind_calls)]
92#![warn(unreachable_pub)]
93// Do not check link redundancy on bootstrapping phase
94#![allow(rustdoc::redundant_explicit_links)]
95#![warn(rustdoc::unescaped_backticks)]
96//
97// Library features:
98// tidy-alphabetical-start
99#![feature(asm_experimental_arch)]
100#![feature(bstr_internals)]
101#![feature(cfg_target_has_reliable_f16_f128)]
102#![feature(const_carrying_mul_add)]
103#![feature(const_cmp)]
104#![feature(const_destruct)]
105#![feature(const_eval_select)]
106#![feature(const_select_unpredictable)]
107#![feature(core_intrinsics)]
108#![feature(coverage_attribute)]
109#![feature(disjoint_bitor)]
110#![feature(offset_of_enum)]
111#![feature(panic_internals)]
112#![feature(pattern_type_macro)]
113#![feature(sealed)]
114#![feature(ub_checks)]
115// tidy-alphabetical-end
116//
117// Language features:
118// tidy-alphabetical-start
119#![feature(abi_unadjusted)]
120#![feature(adt_const_params)]
121#![feature(allow_internal_unsafe)]
122#![feature(allow_internal_unstable)]
123#![feature(auto_traits)]
124#![feature(cfg_sanitize)]
125#![feature(cfg_target_has_atomic)]
126#![feature(cfg_ub_checks)]
127#![feature(const_closures)]
128#![feature(const_precise_live_drops)]
129#![feature(const_trait_impl)]
130#![feature(decl_macro)]
131#![feature(deprecated_suggestion)]
132#![feature(derive_const)]
133#![feature(diagnostic_on_const)]
134#![feature(diagnostic_on_unmatch_args)]
135#![feature(doc_cfg)]
136#![feature(doc_notable_trait)]
137#![feature(extern_types)]
138#![feature(f16)]
139#![feature(f128)]
140#![feature(field_projections)]
141#![feature(freeze_impls)]
142#![feature(fundamental)]
143#![feature(funnel_shifts)]
144#![feature(intra_doc_pointers)]
145#![feature(intrinsics)]
146#![feature(lang_items)]
147#![feature(link_cfg)]
148#![feature(link_llvm_intrinsics)]
149#![feature(macro_metavar_expr)]
150#![feature(macro_metavar_expr_concat)]
151#![feature(marker_trait_attr)]
152#![feature(min_specialization)]
153#![feature(multiple_supertrait_upcastable)]
154#![feature(must_not_suspend)]
155#![feature(negative_impls)]
156#![feature(never_type)]
157#![feature(no_core)]
158#![feature(optimize_attribute)]
159#![feature(pattern_types)]
160#![feature(pin_macro_internals)]
161#![feature(prelude_import)]
162#![feature(repr_simd)]
163#![feature(rustc_attrs)]
164#![feature(rustdoc_internals)]
165#![feature(simd_ffi)]
166#![feature(staged_api)]
167#![feature(stmt_expr_attributes)]
168#![feature(strict_provenance_lints)]
169#![feature(trait_alias)]
170#![feature(transparent_unions)]
171#![feature(try_blocks)]
172#![feature(uint_carryless_mul)]
173#![feature(unboxed_closures)]
174#![feature(unsized_fn_params)]
175#![feature(with_negative_coherence)]
176// tidy-alphabetical-end
177//
178// Target features:
179// tidy-alphabetical-start
180#![feature(aarch64_unstable_target_feature)]
181#![feature(arm_target_feature)]
182#![feature(avx10_target_feature)]
183#![feature(hexagon_target_feature)]
184#![feature(loongarch_target_feature)]
185#![feature(mips_target_feature)]
186#![feature(movrs_target_feature)]
187#![feature(nvptx_target_feature)]
188#![feature(powerpc_target_feature)]
189#![feature(riscv_target_feature)]
190#![feature(rtm_target_feature)]
191#![feature(s390x_target_feature)]
192#![feature(wasm_target_feature)]
193#![feature(x86_amx_intrinsics)]
194// tidy-alphabetical-end
195196// allow using `core::` in intra-doc links
197#[allow(unused_extern_crates)]
198extern crate self as core;
199200/* The core prelude, not as all-encompassing as the std prelude */
201// The compiler expects the prelude definition to be defined before it's use statement.
202pub mod prelude;
203204#[prelude_import]
205#[allow(unused)]
206use prelude::rust_2024::*;
207208#[macro_use]
209mod macros;
210211#[stable(feature = "assert_matches", since = "1.96.0")]
212pub use crate::macros::{assert_matches, debug_assert_matches};
213214#[unstable(feature = "derive_from", issue = "144889")]
215/// Unstable module containing the unstable `From` derive macro.
216pub mod from {
217#[unstable(feature = "derive_from", issue = "144889")]
218pub use crate::macros::builtin::From;
219}
220221mod sealed {
222/// This trait being unreachable from outside the crate
223 /// prevents outside implementations of our extension traits.
224 /// This allows adding more trait methods in the future.
225#[unstable(feature = "sealed", issue = "none")]
226pub trait Sealed {}
227}
228229// We don't export this through #[macro_export] for now, to avoid breakage.
230#[unstable(feature = "autodiff", issue = "124509")]
231#[doc = "This module provides support for automatic differentiation. For precise information on\ndifferences between the `autodiff_forward` and `autodiff_reverse` macros and how to\nuse them, see their respective documentation.\n\n## General usage\n\nAutodiff macros can be applied to almost all function definitions, see below for examples.\nThey can be applied to functions accepting structs, arrays, slices, vectors, tuples, and more.\n\nIt is possible to apply multiple autodiff macros to the same function. As an example, this can\nbe helpful to compute the partial derivatives with respect to `x` and `y` independently:\n```rust,ignore (optional component)\n#[autodiff_forward(dsquare1, Dual, Const, Dual)]\n#[autodiff_forward(dsquare2, Const, Dual, Dual)]\n#[autodiff_forward(dsquare3, Active, Active, Active)]\nfn square(x: f64, y: f64) -> f64 {\n x * x + 2.0 * y\n}\n```\n\nWe also support autodiff on functions with generic parameters:\n```rust,ignore (optional component)\n#[autodiff_forward(generic_derivative, Duplicated, Active)]\nfn generic_f<T: std::ops::Mul<Output = T> + Copy>(x: &T) -> T {\n x * x\n}\n```\n\nor applying autodiff to nested functions:\n```rust,ignore (optional component)\nfn outer(x: f64) -> f64 {\n #[autodiff_forward(inner_derivative, Dual, Const)]\n fn inner(y: f64) -> f64 {\n y * y\n }\n inner_derivative(x, 1.0)\n}\n\nfn main() {\n assert_eq!(outer(3.14), 6.28);\n}\n```\nThe generated function will be available in the same scope as the function differentiated, and\nhave the same private/pub usability.\n\n## Traits and impls\nAutodiff macros can be used in multiple ways in combination with traits:\n```rust,ignore (optional component)\nstruct Foo {\n a: f64,\n}\n\ntrait MyTrait {\n #[autodiff_reverse(df, Const, Active, Active)]\n fn f(&self, x: f64) -> f64;\n}\n\nimpl MyTrait for Foo {\n fn f(&self, x: f64) -> f64 {\n x.sin()\n }\n}\n\nfn main() {\n let foo = Foo { a: 3.0f64 };\n assert_eq!(foo.f(2.0), 2.0_f64.sin());\n assert_eq!(foo.df(2.0, 1.0).1, 2.0_f64.cos());\n}\n```\nIn this case `df` will be the default implementation provided by the library who provided the\ntrait. A user implementing `MyTrait` could then decide to use the default implementation of\n`df`, or overwrite it with a custom implementation as a form of \"custom derivatives\".\n\nOn the other hand, a function generated by either autodiff macro can also be used to implement a\ntrait:\n```rust,ignore (optional component)\nstruct Foo {\n a: f64,\n}\n\ntrait MyTrait {\n fn f(&self, x: f64) -> f64;\n fn df(&self, x: f64, seed: f64) -> (f64, f64);\n}\n\nimpl MyTrait for Foo {\n #[autodiff_reverse(df, Const, Active, Active)]\n fn f(&self, x: f64) -> f64 {\n self.a * 0.25 * (x * x - 1.0 - 2.0 * x.ln())\n }\n}\n```\n\nSimple `impl` blocks without traits are also supported. Differentiating with respect to the\nimplemented struct will then require the use of a \"shadow struct\" to hold the derivatives of the\nstruct fields:\n\n```rust,ignore (optional component)\nstruct OptProblem {\n a: f64,\n b: f64,\n}\n\nimpl OptProblem {\n #[autodiff_reverse(d_objective, Duplicated, Duplicated, Duplicated)]\n fn objective(&self, x: &[f64], out: &mut f64) {\n *out = self.a + x[0].sqrt() * self.b\n }\n}\nfn main() {\n let p = OptProblem { a: 1., b: 2. };\n let mut p_shadow = OptProblem { a: 0., b: 0. };\n let mut dx = [0.0];\n let mut out = 0.0;\n let mut dout = 1.0;\n\n p.d_objective(&mut p_shadow, &x, &mut dx, &mut out, &mut dout);\n}\n```\n\n## Higher-order derivatives\nFinally, it is possible to generate higher-order derivatives (e.g. Hessian) by applying an\nautodiff macro to a function that is already generated by an autodiff macro, via a thin wrapper.\nThe following example uses Forward mode over Reverse mode\n\n```rust,ignore (optional component)\n#[autodiff_reverse(df, Duplicated, Duplicated)]\nfn f(x: &[f64;2], y: &mut f64) {\n *y = x[0] * x[0] + x[1] * x[0]\n}\n\n#[autodiff_forward(h, Dual, Dual, Dual, Dual)]\nfn wrapper(x: &[f64;2], dx: &mut [f64;2], y: &mut f64, dy: &mut f64) {\n df(x, dx, y, dy);\n}\n\nfn main() {\n let mut y = 0.0;\n let x = [2.0, 2.0];\n\n let mut dy = 0.0;\n let mut dx = [1.0, 0.0];\n\n let mut bx = [0.0, 0.0];\n let mut by = 1.0;\n let mut dbx = [0.0, 0.0];\n let mut dby = 0.0;\n h(&x, &mut dx, &mut bx, &mut dbx, &mut y, &mut dy, &mut by, &mut dby);\n assert_eq!(&dbx, [2.0, 1.0]);\n}\n```\n\n## Current limitations:\n\n- Differentiating a function which accepts a `dyn Trait` is currently not supported.\n- Builds without `lto=\"fat\"` are not yet supported.\n- Builds in debug mode are currently more likely to fail compilation.\n"include_str!("../../core/src/autodiff.md")]
232pub mod autodiff {
233#[unstable(feature = "autodiff", issue = "124509")]
234pub use crate::macros::builtin::{autodiff_forward, autodiff_reverse};
235}
236237#[unstable(feature = "contracts", issue = "128044")]
238pub mod contracts;
239240#[unstable(feature = "derive_macro_global_path", issue = "154645")]
241pub use crate::macros::builtin::derive;
242#[stable(feature = "cfg_select", since = "1.95.0")]
243pub use crate::macros::cfg_select;
244245#[macro_use]
246mod internal_macros;
247248#[path = "num/shells/legacy_int_modules.rs"]
249mod legacy_int_modules;
250#[stable(feature = "rust1", since = "1.0.0")]
251#[allow(clippy::useless_attribute)] // FIXME false positive (https://github.com/rust-lang/rust-clippy/issues/15636)
252#[allow(deprecated_in_future)]
253pub use legacy_int_modules::{i8, i16, i32, i64, isize, u8, u16, u32, u64, usize};
254#[stable(feature = "i128", since = "1.26.0")]
255#[allow(clippy::useless_attribute)] // FIXME false positive (https://github.com/rust-lang/rust-clippy/issues/15636)
256#[allow(deprecated_in_future)]
257pub use legacy_int_modules::{i128, u128};
258259#[path = "num/f128.rs"]
260pub mod f128;
261#[path = "num/f16.rs"]
262pub mod f16;
263#[path = "num/f32.rs"]
264pub mod f32;
265#[path = "num/f64.rs"]
266pub mod f64;
267268#[macro_use]
269pub mod num;
270271/* Core modules for ownership management */
272273pub mod hint;
274pub mod intrinsics;
275pub mod mem;
276#[unstable(feature = "profiling_marker_api", issue = "148197")]
277pub mod profiling;
278pub mod ptr;
279#[unstable(feature = "ub_checks", issue = "none")]
280pub mod ub_checks;
281282/* Core language traits */
283284pub mod borrow;
285pub mod clone;
286pub mod cmp;
287pub mod convert;
288pub mod default;
289pub mod error;
290#[unstable(feature = "field_projections", issue = "145383")]
291pub mod field;
292pub mod index;
293pub mod marker;
294pub mod ops;
295296/* Core types and methods on primitives */
297298pub mod any;
299pub mod array;
300pub mod ascii;
301pub mod asserting;
302#[unstable(feature = "async_iterator", issue = "79024")]
303pub mod async_iter;
304#[unstable(feature = "bstr", issue = "134915")]
305pub mod bstr;
306pub mod cell;
307pub mod char;
308pub mod ffi;
309#[unstable(feature = "core_io", issue = "154046")]
310pub mod io;
311pub mod iter;
312pub mod net;
313pub mod option;
314pub mod os;
315pub mod panic;
316pub mod panicking;
317#[unstable(feature = "pattern_type_macro", issue = "123646")]
318pub mod pat;
319pub mod pin;
320#[unstable(feature = "abort_immediate", issue = "154601")]
321pub mod process;
322#[unstable(feature = "random", issue = "130703")]
323pub mod random;
324#[stable(feature = "new_range_inclusive_api", since = "1.95.0")]
325pub mod range;
326pub mod result;
327pub mod sync;
328#[unstable(feature = "unsafe_binders", issue = "130516")]
329pub mod unsafe_binder;
330331pub mod fmt;
332pub mod hash;
333pub mod slice;
334pub mod str;
335pub mod time;
336337pub mod wtf8;
338339pub mod unicode;
340341/* Async */
342pub mod future;
343pub mod task;
344345/* Heap memory allocator trait */
346#[allow(missing_docs)]
347pub mod alloc;
348349// note: does not need to be public
350mod bool;
351mod escape;
352mod tuple;
353mod unit;
354355#[stable(feature = "core_primitive", since = "1.43.0")]
356pub mod primitive;
357358// Pull in the `core_arch` crate directly into core. The contents of
359// `core_arch` are in a different repository: rust-lang/stdarch.
360//
361// `core_arch` depends on core, but the contents of this module are
362// set up in such a way that directly pulling it here works such that the
363// crate uses the this crate as its core.
364#[path = "../../stdarch/crates/core_arch/src/mod.rs"]
365#[allow(
366 missing_docs,
367 missing_debug_implementations,
368 dead_code,
369 unused_imports,
370 unsafe_op_in_unsafe_fn,
371 ambiguous_glob_reexports,
372 deprecated_in_future,
373 unreachable_pub
374)]
375#[allow(rustdoc::bare_urls)]
376mod core_arch;
377378#[stable(feature = "simd_arch", since = "1.27.0")]
379pub mod arch;
380381// Pull in the `core_simd` crate directly into core. The contents of
382// `core_simd` are in a different repository: rust-lang/portable-simd.
383//
384// `core_simd` depends on core, but the contents of this module are
385// set up in such a way that directly pulling it here works such that the
386// crate uses this crate as its core.
387#[path = "../../portable-simd/crates/core_simd/src/mod.rs"]
388#[allow(missing_debug_implementations, dead_code, unsafe_op_in_unsafe_fn)]
389#[allow(rustdoc::bare_urls)]
390#[unstable(feature = "portable_simd", issue = "86656")]
391mod core_simd;
392393#[unstable(feature = "portable_simd", issue = "86656")]
394pub mod simd {
395#![doc = "Portable SIMD module.\n\nThis module offers a portable abstraction for SIMD operations\nthat is not bound to any particular hardware architecture.\n\n# What is \"portable\"?\n\nThis module provides a SIMD implementation that is fast and predictable on any target.\n\n### Portable SIMD works on every target\n\nUnlike target-specific SIMD in `std::arch`, portable SIMD compiles for every target.\nIn this regard, it is just like \"regular\" Rust.\n\n### Portable SIMD is consistent between targets\n\nA program using portable SIMD can expect identical behavior on any target.\nIn most regards, [`Simd<T, N>`] can be thought of as a parallelized `[T; N]` and operates like a sequence of `T`.\n\nThis has one notable exception: a handful of older architectures (e.g. `armv7` and `powerpc`) flush [subnormal](`f32::is_subnormal`) `f32` values to zero.\nOn these architectures, subnormal `f32` input values are replaced with zeros, and any operation producing subnormal `f32` values produces zeros instead.\nThis doesn\'t affect most architectures or programs.\n\n### Operations use the best instructions available\n\nOperations provided by this module compile to the best available SIMD instructions.\n\nPortable SIMD is not a low-level vendor library, and operations in portable SIMD _do not_ necessarily map to a single instruction.\nInstead, they map to a reasonable implementation of the operation for the target.\n\nConsistency between targets is not compromised to use faster or fewer instructions.\nIn some cases, `std::arch` will provide a faster function that has slightly different behavior than the `std::simd` equivalent.\nFor example, `_mm_min_ps`[^1] can be slightly faster than [`SimdFloat::simd_min`](`num::SimdFloat::simd_min`), but does not conform to the IEEE standard also used by [`f32::min`].\nWhen necessary, [`Simd<T, N>`] can be converted to the types provided by `std::arch` to make use of target-specific functions.\n\nMany targets simply don\'t have SIMD, or don\'t support SIMD for a particular element type.\nIn those cases, regular scalar operations are generated instead.\n\n[^1]: `_mm_min_ps(x, y)` is equivalent to `x.simd_lt(y).select(x, y)`\n"include_str!("../../portable-simd/crates/core_simd/src/core_simd_docs.md")]
396397 #[unstable(feature = "portable_simd", issue = "86656")]
398pub use crate::core_simd::simd::*;
399}
400401include!("primitive_docs.rs");