diff --git a/Cargo.lock b/Cargo.lock index ac671046..812a0bc3 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -87,9 +87,9 @@ dependencies = [ [[package]] name = "alloy-rlp" -version = "0.3.9" +version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da0822426598f95e45dd1ea32a738dac057529a709ee645fcc516ffa4cbde08f" +checksum = "f542548a609dca89fcd72b3b9f355928cf844d4363c5eed9c5273a3dd225e097" dependencies = [ "arrayvec", "bytes", @@ -477,7 +477,7 @@ dependencies = [ "semver 1.0.23", "serde", "serde_json", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -488,9 +488,9 @@ checksum = "37b2a672a2cb129a2e41c10b1224bb368f9f37a2b16b612598138befd7b37eb5" [[package]] name = "cc" -version = "1.2.2" +version = "1.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f34d93e62b03caf570cccc334cbc6c2fceca82f39211051345108adcba3eebdc" +checksum = "27f657647bcff5394bf56c7317665bbf790a137a50eaaa5c6bfbb9e27a518f2d" dependencies = [ "shlex", ] @@ -651,9 +651,9 @@ checksum = "c2459377285ad874054d797f3ccebf984978aa39129f6eafde5cdc8315b612f8" [[package]] name = "const_format" -version = "0.2.33" +version = "0.2.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50c655d81ff1114fb0dcdea9225ea9f0cc712a6f8d189378e82bdf62a473a64b" +checksum = "126f97965c8ad46d6d9163268ff28432e8f6a1196a55578867832e3049df63dd" dependencies = [ "const_format_proc_macros", "konst", @@ -661,9 +661,9 @@ dependencies = [ [[package]] name = "const_format_proc_macros" -version = "0.2.33" +version = "0.2.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eff1a44b93f47b1bac19a27932f5c591e43d1ba357ee4f61526c8a25603f0eb1" +checksum = "1d57c2eccfb16dbac1f4e61e206105db5820c9d26c3c472bc17c774259ef7744" dependencies = [ "proc-macro2", "quote", @@ -1064,9 +1064,9 @@ dependencies = [ [[package]] name = "fastrand" -version = "2.2.0" +version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "486f806e73c5707928240ddc295403b1b93c96a02038563881c4a2fd84b81ac4" +checksum = "37909eebbb50d72f9059c3b6d82c0463f2ff062c9e95845c43a6c9c0355411be" [[package]] name = "fastrlp" @@ -1402,9 +1402,9 @@ checksum = "d75a2a4b1b190afb6f5425f10f6a8f959d2ea0b9c2b1d79553551850539e4674" [[package]] name = "js-sys" -version = "0.3.74" +version = "0.3.76" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a865e038f7f6ed956f788f0d7d60c541fff74c7bd74272c5d4cf15c63743e705" +checksum = "6717b6b5b077764fb5966237269cb3c64edddde4b14ce42647430a78ced9e7b7" dependencies = [ "once_cell", "wasm-bindgen", @@ -1595,7 +1595,7 @@ checksum = "77f39368da9228d99987bd8885b74c98eb93bfa94e9d348b351e646447781f94" dependencies = [ "nom", "serde", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -1817,12 +1817,12 @@ checksum = "57c0d7b74b563b49d38dae00a0c37d4d6de9b432382b2892f0574ddcae73fd0a" [[package]] name = "pest" -version = "2.7.14" +version = "2.7.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "879952a81a83930934cbf1786752d6dedc3b1f29e8f8fb2ad1d0a36f377cf442" +checksum = "8b7cafe60d6cf8e62e1b9b2ea516a089c008945bb5a275416789e7db0bc199dc" dependencies = [ "memchr", - "thiserror", + "thiserror 2.0.6", "ucd-trie", ] @@ -2137,7 +2137,7 @@ checksum = "ba009ff324d1fc1b900bd1fdb31564febe58a8ccc8a6fdbb93b543d33b13ca43" dependencies = [ "getrandom", "libredox", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -2278,7 +2278,7 @@ checksum = "82fa69b198d894d84e23afde8e9ab2af4400b2cba20d6bf2b428a8b01c222c5a" dependencies = [ "serde", "serde_json", - "thiserror", + "thiserror 1.0.69", "tracing", ] @@ -2501,7 +2501,7 @@ dependencies = [ "serde", "strum", "strum_macros", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -2520,7 +2520,7 @@ dependencies = [ "lalrpop", "lalrpop-util", "phf", - "thiserror", + "thiserror 1.0.69", "unicode-xid", ] @@ -2606,6 +2606,7 @@ name = "solar-data-structures" version = "0.1.0" dependencies = [ "bumpalo", + "foldhash", "index_vec", "indexmap", "parking_lot", @@ -2644,7 +2645,7 @@ dependencies = [ "solar-config", "solar-data-structures", "solar-macros", - "thiserror", + "thiserror 2.0.6", "tracing", "unicode-width 0.2.0", ] @@ -2850,7 +2851,16 @@ version = "1.0.69" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52" dependencies = [ - "thiserror-impl", + "thiserror-impl 1.0.69", +] + +[[package]] +name = "thiserror" +version = "2.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8fec2a1820ebd077e2b90c4df007bebf344cd394098a13c563957d0afc83ea47" +dependencies = [ + "thiserror-impl 2.0.6", ] [[package]] @@ -2864,6 +2874,17 @@ dependencies = [ "syn 2.0.90", ] +[[package]] +name = "thiserror-impl" +version = "2.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d65750cab40f4ff1929fb1ba509e9914eb756131cef4210da8d5d700d26f6312" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.90", +] + [[package]] name = "thread_local" version = "1.1.8" @@ -3058,9 +3079,9 @@ dependencies = [ [[package]] name = "tracy-client" -version = "0.17.4" +version = "0.17.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "746b078c6a09ebfd5594609049e07116735c304671eaab06ce749854d23435bc" +checksum = "51e295eae54124872df35720dc3a5b1e827c7deee352b342ec7f7e626d0d0ef3" dependencies = [ "loom", "once_cell", @@ -3228,9 +3249,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.97" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d15e63b4482863c109d70a7b8706c1e364eb6ea449b201a76c5b89cedcec2d5c" +checksum = "a474f6281d1d70c17ae7aa6a613c87fce69a127e2624002df63dcb39d6cf6396" dependencies = [ "cfg-if", "once_cell", @@ -3239,13 +3260,12 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.97" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d36ef12e3aaca16ddd3f67922bc63e48e953f126de60bd33ccc0101ef9998cd" +checksum = "5f89bb38646b4f81674e8f5c3fb81b562be1fd936d84320f3264486418519c79" dependencies = [ "bumpalo", "log", - "once_cell", "proc-macro2", "quote", "syn 2.0.90", @@ -3254,9 +3274,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.97" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "705440e08b42d3e4b36de7d66c944be628d579796b8090bfa3471478a2260051" +checksum = "2cc6181fd9a7492eef6fef1f33961e3695e4579b9872a6f7c83aee556666d4fe" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -3264,9 +3284,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.97" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "98c9ae5a76e46f4deecd0f0255cc223cfa18dc9b261213b8aa0c7b36f61b3f1d" +checksum = "30d7a95b763d3c45903ed6c81f156801839e5ee968bb07e534c44df0fcd330c2" dependencies = [ "proc-macro2", "quote", @@ -3277,15 +3297,15 @@ dependencies = [ [[package]] name = "wasm-bindgen-shared" -version = "0.2.97" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6ee99da9c5ba11bd675621338ef6fa52296b76b83305e9b6e5c77d4c286d6d49" +checksum = "943aab3fdaaa029a6e0271b35ea10b72b943135afe9bffca82384098ad0e06a6" [[package]] name = "web-sys" -version = "0.3.74" +version = "0.3.76" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a98bc3c33f0fe7e59ad7cd041b89034fa82a7c2d4365ca538dda6cdaf513863c" +checksum = "04dd7223427d52553d3702c004d3b2fe07c148165faa56313cb00211e31c12bc" dependencies = [ "js-sys", "wasm-bindgen", diff --git a/Cargo.toml b/Cargo.toml index f1d8cd5b..88842b05 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -123,7 +123,7 @@ derive_builder = "0.20.2" derive_more = { version = "1.0", features = ["full"] } match_cfg = "0.1" strum = "0.26" -thiserror = "1.0" +thiserror = ">=1.0" # parallel parking_lot = "0.12" @@ -150,6 +150,7 @@ cfg-if = "1.0" const_format = "0.2" dashmap = "6.0" either = "1" +foldhash = "0.1.3" hex = { package = "const-hex", version = "1.10" } index_vec = "0.1.3" indexmap = "2.2" diff --git a/crates/data-structures/Cargo.toml b/crates/data-structures/Cargo.toml index 2f7dac92..9987f097 100644 --- a/crates/data-structures/Cargo.toml +++ b/crates/data-structures/Cargo.toml @@ -26,6 +26,7 @@ indexmap.workspace = true parking_lot.workspace = true rayon.workspace = true rustc-hash.workspace = true +foldhash.workspace = true smallvec.workspace = true [features] diff --git a/crates/data-structures/src/map.rs b/crates/data-structures/src/map.rs index b18a0609..23a7437c 100644 --- a/crates/data-structures/src/map.rs +++ b/crates/data-structures/src/map.rs @@ -1,10 +1,7 @@ //! Map types. use indexmap::{IndexMap, IndexSet}; -use std::{ - collections::{HashMap, HashSet}, - hash::BuildHasherDefault, -}; +use std::collections::{HashMap, HashSet}; pub use rustc_hash::{self, FxBuildHasher, FxHasher}; @@ -14,10 +11,10 @@ pub type StdEntry<'a, K, V> = std::collections::hash_map::Entry<'a, K, V>; pub type IndexEntry<'a, K, V> = indexmap::map::Entry<'a, K, V>; /// A [`HashMap`] using [`FxHasher`] as its hasher. -pub type FxHashMap = HashMap>; +pub type FxHashMap = HashMap; /// A [`HashSet`] using [`FxHasher`] as its hasher. -pub type FxHashSet = HashSet>; +pub type FxHashSet = HashSet; /// An [`IndexMap`] using [`FxHasher`] as its hasher. -pub type FxIndexMap = IndexMap>; +pub type FxIndexMap = IndexMap; /// An [`IndexSet`] using [`FxHasher`] as its hasher. -pub type FxIndexSet = IndexSet>; +pub type FxIndexSet = IndexSet; diff --git a/crates/interface/src/source_map/file_resolver.rs b/crates/interface/src/source_map/file_resolver.rs index 78ea6b08..97c2053a 100644 --- a/crates/interface/src/source_map/file_resolver.rs +++ b/crates/interface/src/source_map/file_resolver.rs @@ -22,7 +22,7 @@ pub enum ResolveError { ReadFile(PathBuf, #[source] io::Error), #[error("file {0} not found")] NotFound(PathBuf), - #[error("multiple files match {0}: {}", _1.iter().map(|f| f.name.display()).format(", "))] + #[error("multiple files match {}: {}", .0.display(), .1.iter().map(|f| f.name.display()).format(", "))] MultipleMatches(PathBuf, Vec>), } diff --git a/crates/interface/src/symbol.rs b/crates/interface/src/symbol.rs index 975f7c3b..1de30baa 100644 --- a/crates/interface/src/symbol.rs +++ b/crates/interface/src/symbol.rs @@ -417,12 +417,12 @@ impl LassoInterner { unsafe impl lasso::Key for Symbol { #[inline] fn into_usize(self) -> usize { - self.as_u32() as usize + self.0.index() } #[inline] - fn try_from_usize(int: usize) -> Option { - int.try_into().ok().map(Self::new) + fn try_from_usize(value: usize) -> Option { + BaseIndex32::try_from_usize(value).map(Self) } }