std/prelude/
mod.rs

1//! # The Rust Prelude
2//!
3//! Rust comes with a variety of things in its standard library. However, if
4//! you had to manually import every single thing that you used, it would be
5//! very verbose. But importing a lot of things that a program never uses isn't
6//! good either. A balance needs to be struck.
7//!
8//! The *prelude* is the list of things that Rust automatically imports into
9//! every Rust program. It's kept as small as possible, and is focused on
10//! things, particularly traits, which are used in almost every single Rust
11//! program.
12//!
13//! # Other preludes
14//!
15//! Preludes can be seen as a pattern to make using multiple types more
16//! convenient. As such, you'll find other preludes in the standard library,
17//! such as [`std::io::prelude`]. Various libraries in the Rust ecosystem may
18//! also define their own preludes.
19//!
20//! [`std::io::prelude`]: crate::io::prelude
21//!
22//! The difference between 'the prelude' and these other preludes is that they
23//! are not automatically `use`'d, and must be imported manually. This is still
24//! easier than importing all of their constituent components.
25//!
26//! # Prelude contents
27//!
28//! The items included in the prelude depend on the edition of the crate.
29//! The first version of the prelude is used in Rust 2015 and Rust 2018,
30//! and lives in [`std::prelude::v1`].
31//! [`std::prelude::rust_2015`] and [`std::prelude::rust_2018`] re-export this prelude.
32//! It re-exports the following:
33//!
34//! * <code>[std::marker]::{[Copy], [Send], [Sized], [Sync], [Unpin]}</code>,
35//!   marker traits that indicate fundamental properties of types.
36//! * <code>[std::ops]::{[Fn], [FnMut], [FnOnce]}</code>, and their analogous
37//!   async traits, <code>[std::ops]::{[AsyncFn], [AsyncFnMut], [AsyncFnOnce]}</code>.
38//! * <code>[std::ops]::[Drop]</code>, for implementing destructors.
39//! * <code>[std::mem]::[drop]</code>, a convenience function for explicitly
40//!   dropping a value.
41//! * <code>[std::mem]::{[size_of], [size_of_val]}</code>, to get the size of
42//!   a type or value.
43//! * <code>[std::mem]::{[align_of], [align_of_val]}</code>, to get the
44//!   alignment of a type or value.
45//! * <code>[std::boxed]::[Box]</code>, a way to allocate values on the heap.
46//! * <code>[std::borrow]::[ToOwned]</code>, the conversion trait that defines
47//!   [`to_owned`], the generic method for creating an owned type from a
48//!   borrowed type.
49//! * <code>[std::clone]::[Clone]</code>, the ubiquitous trait that defines
50//!   [`clone`][Clone::clone], the method for producing a copy of a value.
51//! * <code>[std::cmp]::{[PartialEq], [PartialOrd], [Eq], [Ord]}</code>, the
52//!   comparison traits, which implement the comparison operators and are often
53//!   seen in trait bounds.
54//! * <code>[std::convert]::{[AsRef], [AsMut], [Into], [From]}</code>, generic
55//!   conversions, used by savvy API authors to create overloaded methods.
56//! * <code>[std::default]::[Default]</code>, types that have default values.
57//! * <code>[std::iter]::{[Iterator], [Extend], [IntoIterator], [DoubleEndedIterator], [ExactSizeIterator]}</code>,
58//!   iterators of various
59//!   kinds.
60//! * <code>[std::option]::[Option]::{[self][Option], [Some], [None]}</code>, a
61//!   type which expresses the presence or absence of a value. This type is so
62//!   commonly used, its variants are also exported.
63//! * <code>[std::result]::[Result]::{[self][Result], [Ok], [Err]}</code>, a type
64//!   for functions that may succeed or fail. Like [`Option`], its variants are
65//!   exported as well.
66//! * <code>[std::string]::{[String], [ToString]}</code>, heap-allocated strings.
67//! * <code>[std::vec]::[Vec]</code>, a growable, heap-allocated vector.
68//!
69//! The prelude used in Rust 2021, [`std::prelude::rust_2021`], includes all of the above,
70//! and in addition re-exports:
71//!
72//! * <code>[std::convert]::{[TryFrom], [TryInto]}</code>.
73//! * <code>[std::iter]::[FromIterator]</code>.
74//!
75//! The prelude used in Rust 2024, [`std::prelude::rust_2024`], includes all of the above,
76//! and in addition re-exports:
77//!
78//! * <code>[std::future]::{[Future], [IntoFuture]}</code>.
79//!
80//! [std::borrow]: crate::borrow
81//! [std::boxed]: crate::boxed
82//! [std::clone]: crate::clone
83//! [std::cmp]: crate::cmp
84//! [std::convert]: crate::convert
85//! [std::default]: crate::default
86//! [std::future]: crate::future
87//! [std::iter]: crate::iter
88//! [std::marker]: crate::marker
89//! [std::mem]: crate::mem
90//! [std::ops]: crate::ops
91//! [std::option]: crate::option
92//! [`std::prelude::v1`]: v1
93//! [`std::prelude::rust_2015`]: rust_2015
94//! [`std::prelude::rust_2018`]: rust_2018
95//! [`std::prelude::rust_2021`]: rust_2021
96//! [`std::prelude::rust_2024`]: rust_2024
97//! [std::result]: crate::result
98//! [std::slice]: crate::slice
99//! [std::string]: crate::string
100//! [std::vec]: mod@crate::vec
101//! [`to_owned`]: crate::borrow::ToOwned::to_owned
102//! [book-closures]: ../../book/ch13-01-closures.html
103//! [book-dtor]: ../../book/ch15-03-drop.html
104//! [book-enums]: ../../book/ch06-01-defining-an-enum.html
105//! [book-iter]: ../../book/ch13-02-iterators.html
106//! [Future]: crate::future::Future
107//! [IntoFuture]: crate::future::IntoFuture
108
109// No formatting: this file is nothing but re-exports, and their order is worth preserving.
110#![cfg_attr(rustfmt, rustfmt::skip)]
111
112#![stable(feature = "rust1", since = "1.0.0")]
113
114pub mod v1;
115
116/// The 2015 version of the prelude of The Rust Standard Library.
117///
118/// See the [module-level documentation](self) for more.
119#[stable(feature = "prelude_2015", since = "1.55.0")]
120pub mod rust_2015 {
121    #[stable(feature = "prelude_2015", since = "1.55.0")]
122    #[doc(no_inline)]
123    pub use super::v1::*;
124}
125
126/// The 2018 version of the prelude of The Rust Standard Library.
127///
128/// See the [module-level documentation](self) for more.
129#[stable(feature = "prelude_2018", since = "1.55.0")]
130pub mod rust_2018 {
131    #[stable(feature = "prelude_2018", since = "1.55.0")]
132    #[doc(no_inline)]
133    pub use super::v1::*;
134}
135
136/// The 2021 version of the prelude of The Rust Standard Library.
137///
138/// See the [module-level documentation](self) for more.
139#[stable(feature = "prelude_2021", since = "1.55.0")]
140pub mod rust_2021 {
141    #[stable(feature = "prelude_2021", since = "1.55.0")]
142    #[doc(no_inline)]
143    pub use super::v1::*;
144
145    #[stable(feature = "prelude_2021", since = "1.55.0")]
146    #[doc(no_inline)]
147    pub use core::prelude::rust_2021::*;
148}
149
150/// The 2024 version of the prelude of The Rust Standard Library.
151///
152/// See the [module-level documentation](self) for more.
153#[stable(feature = "prelude_2024", since = "1.85.0")]
154pub mod rust_2024 {
155    #[stable(feature = "rust1", since = "1.0.0")]
156    #[doc(no_inline)]
157    pub use super::v1::*;
158
159    #[stable(feature = "prelude_2024", since = "1.85.0")]
160    #[doc(no_inline)]
161    pub use core::prelude::rust_2024::*;
162}