Skip to content

Commit

Permalink
Add module docs and restrict visibility
Browse files Browse the repository at this point in the history
  • Loading branch information
ecstatic-morse committed Apr 23, 2020
1 parent 59c7460 commit 34dfbc3
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 5 deletions.
2 changes: 1 addition & 1 deletion src/librustc_middle/mir/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ pub struct Body<'tcx> {
/// FIXME(oli-obk): rewrite the promoted during promotion to eliminate the cell components.
pub ignore_interior_mut_in_const_validation: bool,

pub predecessor_cache: PredecessorCache,
predecessor_cache: PredecessorCache,
}

impl<'tcx> Body<'tcx> {
Expand Down
10 changes: 6 additions & 4 deletions src/librustc_middle/mir/predecessors.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//! Lazily compute the reverse control-flow graph for the MIR.

use rustc_data_structures::stable_hasher::{HashStable, StableHasher};
use rustc_data_structures::sync::{Lock, Lrc};
use rustc_index::vec::IndexVec;
Expand All @@ -10,13 +12,13 @@ use crate::mir::{BasicBlock, BasicBlockData};
pub type Predecessors = IndexVec<BasicBlock, SmallVec<[BasicBlock; 4]>>;

#[derive(Clone, Debug)]
pub struct PredecessorCache {
pub(super) struct PredecessorCache {
cache: Lock<Option<Lrc<Predecessors>>>,
}

impl PredecessorCache {
#[inline]
pub fn new() -> Self {
pub(super) fn new() -> Self {
PredecessorCache { cache: Lock::new(None) }
}

Expand All @@ -27,7 +29,7 @@ impl PredecessorCache {
/// callers of `invalidate` have a unique reference to the MIR and thus to the predecessor
/// cache. This means we don't actually need to take a lock when `invalidate` is called.
#[inline]
pub fn invalidate(&mut self) {
pub(super) fn invalidate(&mut self) {
*self.cache.get_mut() = None;
}

Expand All @@ -37,7 +39,7 @@ impl PredecessorCache {
/// `cache` is only held inside this function. As long as no other locks are taken while
/// computing the predecessor graph, deadlock is impossible.
#[inline]
pub fn compute(
pub(super) fn compute(
&self,
basic_blocks: &IndexVec<BasicBlock, BasicBlockData<'_>>,
) -> Lrc<Predecessors> {
Expand Down

0 comments on commit 34dfbc3

Please sign in to comment.