1 //! Various data structures used by the Rust compiler. The intention
2 //! is that code in here should be not be *specific* to rustc, so that
3 //! it can be easily unit tested and so forth.
7 //! This API is completely unstable and subject to change.
9 #![doc(html_root_url = "https://doc.rust-lang.org/nightly/nightly-rustc/")]
10 #![feature(array_windows)]
11 #![feature(control_flow_enum)]
12 #![feature(in_band_lifetimes)]
13 #![feature(unboxed_closures)]
14 #![feature(generator_trait)]
15 #![feature(fn_traits)]
16 #![feature(int_bits_const)]
17 #![feature(min_specialization)]
18 #![feature(auto_traits)]
20 #![feature(allow_internal_unstable)]
21 #![feature(hash_raw_entry)]
22 #![feature(stmt_expr_attributes)]
23 #![feature(core_intrinsics)]
25 #![feature(associated_type_bounds)]
26 #![feature(thread_id_value)]
27 #![feature(extend_one)]
28 #![feature(const_panic)]
29 #![feature(new_uninit)]
30 #![feature(once_cell)]
31 #![feature(maybe_uninit_uninit_array)]
32 #![allow(rustc::default_hash_types)]
33 #![deny(unaligned_references)]
40 extern crate rustc_macros
;
44 pub fn cold_path
<F
: FnOnce() -> R
, R
>(f
: F
) -> R
{
52 #[allow(unused_unsafe)]
53 e
=> unsafe { std::intrinsics::likely(e) }
,
59 macro_rules
! unlikely
{
62 #[allow(unused_unsafe)]
63 e
=> unsafe { std::intrinsics::unlikely(e) }
,
69 pub mod binary_search_util
;
79 pub mod obligation_forest
;
87 pub use ena
::snapshot_vec
;
91 pub mod stable_hasher
;
100 pub mod transitive_relation
;
101 pub mod vec_linked_list
;
103 pub use atomic_ref
::AtomicRef
;
111 pub use ena
::undo_log
;
114 pub struct OnDrop
<F
: Fn()>(pub F
);
116 impl<F
: Fn()> OnDrop
<F
> {
117 /// Forgets the function which prevents it from running.
118 /// Ensure that the function owns no memory, otherwise it will be leaked.
120 pub fn disable(self) {
121 std
::mem
::forget(self);
125 impl<F
: Fn()> Drop
for OnDrop
<F
> {
132 // See comments in src/librustc_middle/lib.rs
134 pub fn __noop_fix_for_27438() {}