2023-12-18 11:09:54 +00:00
|
|
|
use hir::{db::ExpandDatabase, ProcMacros};
|
2022-04-25 16:51:59 +00:00
|
|
|
use ide_db::{
|
2023-12-18 11:09:54 +00:00
|
|
|
base_db::{salsa::Durability, CrateGraph, SourceDatabase},
|
2022-04-25 16:51:59 +00:00
|
|
|
FxHashMap, RootDatabase,
|
|
|
|
};
|
2023-05-02 14:12:22 +00:00
|
|
|
use triomphe::Arc;
|
2021-12-07 14:38:12 +00:00
|
|
|
|
|
|
|
// Feature: Shuffle Crate Graph
|
|
|
|
//
|
|
|
|
// Randomizes all crate IDs in the crate graph, for debugging.
|
|
|
|
//
|
|
|
|
// |===
|
|
|
|
// | Editor | Action Name
|
|
|
|
//
|
2022-08-01 11:47:09 +00:00
|
|
|
// | VS Code | **rust-analyzer: Shuffle Crate Graph**
|
2021-12-07 14:38:12 +00:00
|
|
|
// |===
|
|
|
|
pub(crate) fn shuffle_crate_graph(db: &mut RootDatabase) {
|
|
|
|
let crate_graph = db.crate_graph();
|
2023-03-25 15:42:52 +00:00
|
|
|
let proc_macros = db.proc_macros();
|
2021-12-07 14:38:12 +00:00
|
|
|
|
|
|
|
let mut shuffled_ids = crate_graph.iter().collect::<Vec<_>>();
|
2023-02-14 00:56:28 +00:00
|
|
|
|
|
|
|
let mut rng = oorandom::Rand32::new(stdx::rand::seed());
|
|
|
|
stdx::rand::shuffle(&mut shuffled_ids, |i| rng.rand_range(0..i as u32) as usize);
|
2021-12-07 14:38:12 +00:00
|
|
|
|
|
|
|
let mut new_graph = CrateGraph::default();
|
2023-03-25 15:42:52 +00:00
|
|
|
let mut new_proc_macros = ProcMacros::default();
|
2021-12-07 14:38:12 +00:00
|
|
|
|
|
|
|
let mut map = FxHashMap::default();
|
|
|
|
for old_id in shuffled_ids.iter().copied() {
|
|
|
|
let data = &crate_graph[old_id];
|
|
|
|
let new_id = new_graph.add_crate_root(
|
|
|
|
data.root_file_id,
|
|
|
|
data.edition,
|
|
|
|
data.display_name.clone(),
|
|
|
|
data.version.clone(),
|
|
|
|
data.cfg_options.clone(),
|
|
|
|
data.potential_cfg_options.clone(),
|
|
|
|
data.env.clone(),
|
2022-03-09 13:33:39 +00:00
|
|
|
data.is_proc_macro,
|
2021-12-07 14:38:12 +00:00
|
|
|
data.origin.clone(),
|
|
|
|
);
|
2023-03-25 15:42:52 +00:00
|
|
|
new_proc_macros.insert(new_id, proc_macros[&old_id].clone());
|
2021-12-07 14:38:12 +00:00
|
|
|
map.insert(old_id, new_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
for old_id in shuffled_ids.iter().copied() {
|
|
|
|
let data = &crate_graph[old_id];
|
|
|
|
for dep in &data.dependencies {
|
|
|
|
let mut new_dep = dep.clone();
|
|
|
|
new_dep.crate_id = map[&dep.crate_id];
|
|
|
|
new_graph.add_dep(map[&old_id], new_dep).unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
db.set_crate_graph_with_durability(Arc::new(new_graph), Durability::HIGH);
|
2023-03-25 15:42:52 +00:00
|
|
|
db.set_proc_macros_with_durability(Arc::new(new_proc_macros), Durability::HIGH);
|
2021-12-07 14:38:12 +00:00
|
|
|
}
|