From ac0839cb2a1e7e7226f1336f59ecc69c18228e22 Mon Sep 17 00:00:00 2001 From: Predrag Gruevski Date: Thu, 16 Jan 2025 18:33:49 +0000 Subject: [PATCH] Use rustc-hash everywhere internally as well. --- .github/workflows/ci.yml | 6 ++++++ src/adapter/edges.rs | 3 ++- src/adapter/enum_variant.rs | 3 ++- src/adapter/optimizations/impl_lookup.rs | 4 ++++ src/adapter/optimizations/method_lookup.rs | 8 +++++++- src/indexed_crate.rs | 12 +++++++++--- src/visibility_tracker.rs | 5 +++-- 7 files changed, 33 insertions(+), 8 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2da27746..076a32ec 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -94,6 +94,12 @@ jobs: - name: test with rayon run: cargo test --features rayon + - name: compile with rayon and rustc-hash + run: cargo test --no-run --features rayon,rustc-hash + + - name: test with rayon and rustc-hash + run: cargo test --features rayon,rustc-hash + publish: name: Publish to crates.io runs-on: ubuntu-latest diff --git a/src/adapter/edges.rs b/src/adapter/edges.rs index 97c7c845..08ee1d98 100644 --- a/src/adapter/edges.rs +++ b/src/adapter/edges.rs @@ -1,7 +1,8 @@ +use std::{num::NonZeroUsize, rc::Rc}; + use rustdoc_types::{ GenericBound::TraitBound, GenericParamDefKind, Id, ItemEnum, VariantKind, WherePredicate, }; -use std::{num::NonZeroUsize, rc::Rc}; use trustfall::provider::{ resolve_neighbors_with, AsVertex, ContextIterator, ContextOutcomeIterator, ResolveEdgeInfo, VertexIterator, diff --git a/src/adapter/enum_variant.rs b/src/adapter/enum_variant.rs index 8638a33b..40e39215 100644 --- a/src/adapter/enum_variant.rs +++ b/src/adapter/enum_variant.rs @@ -1,4 +1,3 @@ -use rustdoc_types::{Item, ItemEnum, Variant}; use std::borrow::Cow; use std::cell::OnceCell; use std::fmt::{self, Debug}; @@ -6,6 +5,8 @@ use std::num::ParseIntError; use std::rc::Rc; use std::str::FromStr; +use rustdoc_types::{Item, ItemEnum, Variant}; + #[non_exhaustive] #[derive(Debug, Clone)] pub struct EnumVariant<'a> { diff --git a/src/adapter/optimizations/impl_lookup.rs b/src/adapter/optimizations/impl_lookup.rs index 3e4156ba..37182366 100644 --- a/src/adapter/optimizations/impl_lookup.rs +++ b/src/adapter/optimizations/impl_lookup.rs @@ -1,5 +1,9 @@ +#[cfg(not(feature = "rustc-hash"))] use std::collections::HashMap; +#[cfg(feature = "rustc-hash")] +use rustc_hash::FxHashMap as HashMap; + use rustdoc_types::{Id, Item}; use trustfall::{ provider::{ diff --git a/src/adapter/optimizations/method_lookup.rs b/src/adapter/optimizations/method_lookup.rs index 3b249d4a..7fb1befc 100644 --- a/src/adapter/optimizations/method_lookup.rs +++ b/src/adapter/optimizations/method_lookup.rs @@ -1,4 +1,10 @@ -use std::collections::{BTreeSet, HashMap}; +use std::collections::BTreeSet; + +#[cfg(not(feature = "rustc-hash"))] +use std::collections::HashMap; + +#[cfg(feature = "rustc-hash")] +use rustc_hash::FxHashMap as HashMap; use rustdoc_types::{Id, Impl, Item, ItemEnum, Type}; use trustfall::{ diff --git a/src/indexed_crate.rs b/src/indexed_crate.rs index b281047c..397f6aef 100644 --- a/src/indexed_crate.rs +++ b/src/indexed_crate.rs @@ -1,9 +1,15 @@ use std::{ borrow::Borrow, - collections::{hash_map::Entry, HashMap, HashSet}, + collections::hash_map::Entry, sync::Arc, }; +#[cfg(not(feature = "rustc-hash"))] +use std::collections::{HashMap, HashSet}; + +#[cfg(feature = "rustc-hash")] +use rustc_hash::{FxHashMap as HashMap, FxHashSet as HashSet}; + #[cfg(feature = "rayon")] use rayon::prelude::*; use rustdoc_types::{Crate, Id, Item}; @@ -270,7 +276,7 @@ impl Extend<(K, V)> for MapList { impl MapList { #[inline] pub fn new() -> Self { - Self(HashMap::new()) + Self(HashMap::default()) } #[inline] @@ -786,7 +792,7 @@ fn new_trait(manual_trait_item: &ManualTraitItem, id: Id, crate_id: u32) -> Item span: None, visibility: rustdoc_types::Visibility::Public, docs: None, - links: HashMap::new(), + links: HashMap::default(), attrs: Vec::new(), deprecation: None, inner: rustdoc_types::ItemEnum::Trait(rustdoc_types::Trait { diff --git a/src/visibility_tracker.rs b/src/visibility_tracker.rs index e1d7e33e..ccacf41f 100644 --- a/src/visibility_tracker.rs +++ b/src/visibility_tracker.rs @@ -1,8 +1,9 @@ -#[cfg(feature = "rustc-hash")] -use rustc_hash::{FxHashMap as HashMap, FxHashSet as HashSet}; #[cfg(not(feature = "rustc-hash"))] use std::collections::{HashMap, HashSet}; +#[cfg(feature = "rustc-hash")] +use rustc_hash::{FxHashMap as HashMap, FxHashSet as HashSet}; + use rustdoc_types::{Crate, GenericArgs, Id, Item, ItemEnum, TypeAlias, Visibility}; #[cfg(feature = "rayon")]