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/")]
10 #![feature(in_band_lifetimes)]
11 #![feature(unboxed_closures)]
12 #![feature(generators)]
13 #![feature(generator_trait)]
14 #![feature(fn_traits)]
15 #![feature(min_specialization)]
16 #![feature(optin_builtin_traits)]
18 #![feature(allow_internal_unstable)]
19 #![feature(hash_raw_entry)]
20 #![feature(stmt_expr_attributes)]
21 #![feature(core_intrinsics)]
23 #![feature(associated_type_bounds)]
24 #![feature(thread_id_value)]
25 #![feature(extend_one)]
26 #![allow(rustc::default_hash_types)]
35 pub fn cold_path<F: FnOnce() -> R, R>(f: F) -> R {
42 #[allow(unused_unsafe)]
44 unsafe { std::intrinsics::likely($e) }
50 macro_rules! unlikely {
52 #[allow(unused_unsafe)]
54 unsafe { std::intrinsics::unlikely($e) }
60 pub mod binary_search_util;
70 pub mod obligation_forest;
78 pub use ena::snapshot_vec;
82 pub mod stable_hasher;
88 pub mod transitive_relation;
89 pub use ena::undo_log;
94 pub mod vec_linked_list;
96 pub use atomic_ref::AtomicRef;
100 pub struct OnDrop<F: Fn()>(pub F);
102 impl<F: Fn()> OnDrop<F> {
103 /// Forgets the function which prevents it from running.
104 /// Ensure that the function owns no memory, otherwise it will be leaked.
106 pub fn disable(self) {
107 std::mem::forget(self);
111 impl<F: Fn()> Drop for OnDrop<F> {
118 // See comments in src/librustc_middle/lib.rs
120 pub fn __noop_fix_for_27438() {}