]> git.lizzy.rs Git - rust.git/blob - compiler/rustc_middle/src/lib.rs
Auto merge of #94738 - Urgau:rustbuild-check-cfg-values, r=Mark-Simulacrum
[rust.git] / compiler / rustc_middle / src / lib.rs
1 //! The "main crate" of the Rust compiler. This crate contains common
2 //! type definitions that are used by the other crates in the rustc
3 //! "family". Some prominent examples (note that each of these modules
4 //! has their own README with further details).
5 //!
6 //! - **HIR.** The "high-level (H) intermediate representation (IR)" is
7 //!   defined in the `hir` module.
8 //! - **MIR.** The "mid-level (M) intermediate representation (IR)" is
9 //!   defined in the `mir` module. This module contains only the
10 //!   *definition* of the MIR; the passes that transform and operate
11 //!   on MIR are found in `rustc_const_eval` crate.
12 //! - **Types.** The internal representation of types used in rustc is
13 //!   defined in the `ty` module. This includes the **type context**
14 //!   (or `tcx`), which is the central context during most of
15 //!   compilation, containing the interners and other things.
16 //!
17 //! For more information about how rustc works, see the [rustc dev guide].
18 //!
19 //! [rustc dev guide]: https://rustc-dev-guide.rust-lang.org/
20 //!
21 //! # Note
22 //!
23 //! This API is completely unstable and subject to change.
24
25 #![doc(html_root_url = "https://doc.rust-lang.org/nightly/nightly-rustc/")]
26 #![feature(allocator_api)]
27 #![feature(array_windows)]
28 #![feature(assert_matches)]
29 #![feature(backtrace)]
30 #![feature(bool_to_option)]
31 #![feature(box_patterns)]
32 #![feature(core_intrinsics)]
33 #![feature(derive_default_enum)]
34 #![feature(discriminant_kind)]
35 #![feature(exhaustive_patterns)]
36 #![feature(get_mut_unchecked)]
37 #![feature(if_let_guard)]
38 #![feature(map_first_last)]
39 #![feature(never_type)]
40 #![feature(extern_types)]
41 #![feature(new_uninit)]
42 #![feature(nll)]
43 #![feature(once_cell)]
44 #![feature(let_else)]
45 #![feature(min_specialization)]
46 #![feature(trusted_len)]
47 #![feature(type_alias_impl_trait)]
48 #![feature(crate_visibility_modifier)]
49 #![feature(associated_type_bounds)]
50 #![feature(rustc_attrs)]
51 #![feature(half_open_range_patterns)]
52 #![feature(control_flow_enum)]
53 #![feature(associated_type_defaults)]
54 #![feature(trusted_step)]
55 #![feature(try_blocks)]
56 #![feature(try_reserve_kind)]
57 #![feature(nonzero_ops)]
58 #![feature(unwrap_infallible)]
59 #![feature(decl_macro)]
60 #![feature(drain_filter)]
61 #![recursion_limit = "512"]
62 #![allow(rustc::potential_query_instability)]
63
64 #[macro_use]
65 extern crate bitflags;
66 #[macro_use]
67 extern crate rustc_macros;
68 #[macro_use]
69 extern crate rustc_data_structures;
70 #[macro_use]
71 extern crate tracing;
72 #[macro_use]
73 extern crate smallvec;
74
75 #[cfg(test)]
76 mod tests;
77
78 #[macro_use]
79 mod macros;
80
81 #[macro_use]
82 pub mod query;
83
84 #[macro_use]
85 pub mod arena;
86 #[macro_use]
87 pub mod dep_graph;
88 pub mod hir;
89 pub mod infer;
90 pub mod lint;
91 pub mod metadata;
92 pub mod middle;
93 pub mod mir;
94 pub mod thir;
95 pub mod traits;
96 pub mod ty;
97
98 pub mod util {
99     pub mod bug;
100     pub mod common;
101 }
102
103 // Allows macros to refer to this crate as `::rustc_middle`
104 extern crate self as rustc_middle;