Cache ignored attributes inside ICH entirely
This commit is contained in:
parent
bd6fe1e700
commit
ed246fcc95
@ -37,7 +37,7 @@ use rustc_data_structures::stable_hasher::{HashStable,
|
|||||||
use rustc_data_structures::accumulate_vec::AccumulateVec;
|
use rustc_data_structures::accumulate_vec::AccumulateVec;
|
||||||
use rustc_data_structures::fx::{FxHashSet, FxHashMap};
|
use rustc_data_structures::fx::{FxHashSet, FxHashMap};
|
||||||
|
|
||||||
pub fn compute_ignored_attr_names() -> FxHashSet<Symbol> {
|
fn compute_ignored_attr_names() -> FxHashSet<Symbol> {
|
||||||
debug_assert!(ich::IGNORED_ATTRIBUTES.len() > 0);
|
debug_assert!(ich::IGNORED_ATTRIBUTES.len() > 0);
|
||||||
ich::IGNORED_ATTRIBUTES.iter().map(|&s| Symbol::intern(s)).collect()
|
ich::IGNORED_ATTRIBUTES.iter().map(|&s| Symbol::intern(s)).collect()
|
||||||
}
|
}
|
||||||
@ -183,7 +183,10 @@ impl<'a> StableHashingContext<'a> {
|
|||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn is_ignored_attr(&self, name: Symbol) -> bool {
|
pub fn is_ignored_attr(&self, name: Symbol) -> bool {
|
||||||
self.sess.ignored_attr_names.contains(&name)
|
thread_local! {
|
||||||
|
static IGNORED_ATTRIBUTES: FxHashSet<Symbol> = compute_ignored_attr_names();
|
||||||
|
}
|
||||||
|
IGNORED_ATTRIBUTES.with(|attrs| attrs.contains(&name))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn hash_hir_item_like<F: FnOnce(&mut Self)>(&mut self, f: F) {
|
pub fn hash_hir_item_like<F: FnOnce(&mut Self)>(&mut self, f: F) {
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
crate use rustc_data_structures::fingerprint::Fingerprint;
|
crate use rustc_data_structures::fingerprint::Fingerprint;
|
||||||
pub use self::caching_codemap_view::CachingCodemapView;
|
pub use self::caching_codemap_view::CachingCodemapView;
|
||||||
pub use self::hcx::{StableHashingContextProvider, StableHashingContext, NodeIdHashingMode,
|
pub use self::hcx::{StableHashingContextProvider, StableHashingContext, NodeIdHashingMode,
|
||||||
hash_stable_trait_impls, compute_ignored_attr_names};
|
hash_stable_trait_impls};
|
||||||
mod caching_codemap_view;
|
mod caching_codemap_view;
|
||||||
mod hcx;
|
mod hcx;
|
||||||
|
|
||||||
|
@ -14,7 +14,6 @@ use self::code_stats::CodeStats;
|
|||||||
use hir::def_id::CrateNum;
|
use hir::def_id::CrateNum;
|
||||||
use rustc_data_structures::fingerprint::Fingerprint;
|
use rustc_data_structures::fingerprint::Fingerprint;
|
||||||
|
|
||||||
use ich;
|
|
||||||
use lint;
|
use lint;
|
||||||
use lint::builtin::BuiltinLintDiagnostics;
|
use lint::builtin::BuiltinLintDiagnostics;
|
||||||
use middle::allocator::AllocatorKind;
|
use middle::allocator::AllocatorKind;
|
||||||
@ -34,7 +33,6 @@ use errors::emitter::{Emitter, EmitterWriter};
|
|||||||
use syntax::edition::Edition;
|
use syntax::edition::Edition;
|
||||||
use syntax::json::JsonEmitter;
|
use syntax::json::JsonEmitter;
|
||||||
use syntax::feature_gate;
|
use syntax::feature_gate;
|
||||||
use syntax::symbol::Symbol;
|
|
||||||
use syntax::parse;
|
use syntax::parse;
|
||||||
use syntax::parse::ParseSess;
|
use syntax::parse::ParseSess;
|
||||||
use syntax::{ast, codemap};
|
use syntax::{ast, codemap};
|
||||||
@ -128,9 +126,6 @@ pub struct Session {
|
|||||||
|
|
||||||
incr_comp_session: OneThread<RefCell<IncrCompSession>>,
|
incr_comp_session: OneThread<RefCell<IncrCompSession>>,
|
||||||
|
|
||||||
/// A cache of attributes ignored by StableHashingContext
|
|
||||||
pub ignored_attr_names: FxHashSet<Symbol>,
|
|
||||||
|
|
||||||
/// Used by -Z profile-queries in util::common
|
/// Used by -Z profile-queries in util::common
|
||||||
pub profile_channel: Lock<Option<mpsc::Sender<ProfileQueriesMsg>>>,
|
pub profile_channel: Lock<Option<mpsc::Sender<ProfileQueriesMsg>>>,
|
||||||
|
|
||||||
@ -1143,7 +1138,6 @@ pub fn build_session_(
|
|||||||
injected_panic_runtime: Once::new(),
|
injected_panic_runtime: Once::new(),
|
||||||
imported_macro_spans: OneThread::new(RefCell::new(HashMap::new())),
|
imported_macro_spans: OneThread::new(RefCell::new(HashMap::new())),
|
||||||
incr_comp_session: OneThread::new(RefCell::new(IncrCompSession::NotInitialized)),
|
incr_comp_session: OneThread::new(RefCell::new(IncrCompSession::NotInitialized)),
|
||||||
ignored_attr_names: ich::compute_ignored_attr_names(),
|
|
||||||
self_profiling: Lock::new(SelfProfiler::new()),
|
self_profiling: Lock::new(SelfProfiler::new()),
|
||||||
profile_channel: Lock::new(None),
|
profile_channel: Lock::new(None),
|
||||||
perf_stats: PerfStats {
|
perf_stats: PerfStats {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user