Switch to id-arena

This commit is contained in:
Aleksey Kladov 2018-11-26 00:46:13 +03:00
parent 8a572043e7
commit ed023929d5
5 changed files with 27 additions and 49 deletions

7
Cargo.lock generated
View file

@ -350,6 +350,11 @@ name = "humansize"
version = "1.1.0" version = "1.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
[[package]]
name = "id-arena"
version = "1.0.2"
source = "git+https://github.com/fitzgen/id-arena/?rev=43ecd67#43ecd67d81f707dfdc1b0d067b96c17f7a7ef9b8"
[[package]] [[package]]
name = "idna" name = "idna"
version = "0.1.5" version = "0.1.5"
@ -599,6 +604,7 @@ name = "ra_analysis"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"fst 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "fst 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)",
"id-arena 1.0.2 (git+https://github.com/fitzgen/id-arena/?rev=43ecd67)",
"log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)",
"parking_lot 0.6.4 (registry+https://github.com/rust-lang/crates.io-index)", "parking_lot 0.6.4 (registry+https://github.com/rust-lang/crates.io-index)",
"ra_editor 0.1.0", "ra_editor 0.1.0",
@ -1301,6 +1307,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
"checksum glob 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "8be18de09a56b60ed0edf84bc9df007e30040691af7acd1c41874faac5895bfb" "checksum glob 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "8be18de09a56b60ed0edf84bc9df007e30040691af7acd1c41874faac5895bfb"
"checksum heck 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ea04fa3ead4e05e51a7c806fc07271fdbde4e246a6c6d1efd52e72230b771b82" "checksum heck 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ea04fa3ead4e05e51a7c806fc07271fdbde4e246a6c6d1efd52e72230b771b82"
"checksum humansize 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b6cab2627acfc432780848602f3f558f7e9dd427352224b0d9324025796d2a5e" "checksum humansize 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b6cab2627acfc432780848602f3f558f7e9dd427352224b0d9324025796d2a5e"
"checksum id-arena 1.0.2 (git+https://github.com/fitzgen/id-arena/?rev=43ecd67)" = "<none>"
"checksum idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "38f09e0f0b1fb55fdee1f17470ad800da77af5186a1a76c026b679358b7e844e" "checksum idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "38f09e0f0b1fb55fdee1f17470ad800da77af5186a1a76c026b679358b7e844e"
"checksum im 12.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ae9c7f9bb8aee47fc16d535a705f7867a9fc83bb822e5e1043bb98e77ffeed3c" "checksum im 12.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ae9c7f9bb8aee47fc16d535a705f7867a9fc83bb822e5e1043bb98e77ffeed3c"
"checksum indexmap 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)" = "7e81a7c05f79578dbc15793d8b619db9ba32b4577003ef3af1a91c416798c58d" "checksum indexmap 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)" = "7e81a7c05f79578dbc15793d8b619db9ba32b4577003ef3af1a91c416798c58d"

View file

@ -12,6 +12,7 @@ fst = "0.3.1"
salsa = "0.8.0" salsa = "0.8.0"
rustc-hash = "1.0" rustc-hash = "1.0"
parking_lot = "0.6.4" parking_lot = "0.6.4"
id-arena = { git = "https://github.com/fitzgen/id-arena/", rev = "43ecd67" }
ra_syntax = { path = "../ra_syntax" } ra_syntax = { path = "../ra_syntax" }
ra_editor = { path = "../ra_editor" } ra_editor = { path = "../ra_editor" }
test_utils = { path = "../test_utils" } test_utils = { path = "../test_utils" }

View file

@ -4,7 +4,6 @@
use std::{ use std::{
fmt, fmt,
ops::{Index, IndexMut},
hash::{Hash, Hasher}, hash::{Hash, Hasher},
marker::PhantomData, marker::PhantomData,
}; };
@ -41,56 +40,27 @@ impl<T> Hash for Id<T> {
} }
#[derive(Debug, PartialEq, Eq)] #[derive(Debug, PartialEq, Eq)]
pub(crate) struct Arena<T> { pub(crate) struct ArenaBehavior<T> {
data: Vec<T>, _ty: PhantomData<T>,
} }
impl<T> Default for Arena<T> { impl<T> id_arena::ArenaBehavior for ArenaBehavior<T> {
fn default() -> Arena<T> { type Id = Id<T>;
Arena { data: Vec::new() } fn new_arena_id() -> usize {
0
} }
} fn new_id(_arena_id: usize, index: usize) -> Id<T> {
impl<T> Arena<T> {
pub(crate) fn push(&mut self, value: T) -> Id<T> {
let id = self.data.len() as u32;
self.data.push(value);
Id { Id {
idx: id as u32, idx: index as u32,
_ty: PhantomData, _ty: PhantomData,
} }
} }
fn index(id: Id<T>) -> usize {
pub(crate) fn keys<'a>(&'a self) -> impl Iterator<Item = Id<T>> + 'a { id.idx as usize
(0..(self.data.len() as u32)).into_iter().map(|idx| Id {
idx,
_ty: PhantomData,
})
} }
fn arena_id(_id: Id<T>) -> usize {
pub(crate) fn items<'a>(&'a self) -> impl Iterator<Item = (Id<T>, &T)> + 'a { 0
self.data.iter().enumerate().map(|(idx, item)| {
let idx = idx as u32;
(
Id {
idx,
_ty: PhantomData,
},
item,
)
})
} }
} }
impl<T> Index<Id<T>> for Arena<T> { pub(crate) type Arena<T> = id_arena::Arena<T, ArenaBehavior<T>>;
type Output = T;
fn index(&self, id: Id<T>) -> &T {
&self.data[id.idx as usize]
}
}
impl<T> IndexMut<Id<T>> for Arena<T> {
fn index_mut(&mut self, id: Id<T>) -> &mut T {
&mut self.data[id.idx as usize]
}
}

View file

@ -58,13 +58,13 @@ impl FnScopes {
}) })
} }
fn root_scope(&mut self) -> ScopeId { fn root_scope(&mut self) -> ScopeId {
self.scopes.push(ScopeData { self.scopes.alloc(ScopeData {
parent: None, parent: None,
entries: vec![], entries: vec![],
}) })
} }
fn new_scope(&mut self, parent: ScopeId) -> ScopeId { fn new_scope(&mut self, parent: ScopeId) -> ScopeId {
self.scopes.push(ScopeData { self.scopes.alloc(ScopeData {
parent: Some(parent), parent: Some(parent),
entries: vec![], entries: vec![],
}) })

View file

@ -166,12 +166,12 @@ pub(crate) struct ModuleTree {
impl ModuleTree { impl ModuleTree {
fn modules<'a>(&'a self) -> impl Iterator<Item = ModuleId> + 'a { fn modules<'a>(&'a self) -> impl Iterator<Item = ModuleId> + 'a {
self.mods.keys() self.mods.iter().map(|(id, _)| id)
} }
fn modules_for_source(&self, source: ModuleSource) -> Vec<ModuleId> { fn modules_for_source(&self, source: ModuleSource) -> Vec<ModuleId> {
self.mods self.mods
.items() .iter()
.filter(|(_idx, it)| it.source == source) .filter(|(_idx, it)| it.source == source)
.map(|(idx, _)| idx) .map(|(idx, _)| idx)
.collect() .collect()
@ -333,11 +333,11 @@ struct LinkData {
impl ModuleTree { impl ModuleTree {
fn push_mod(&mut self, data: ModuleData) -> ModuleId { fn push_mod(&mut self, data: ModuleData) -> ModuleId {
self.mods.push(data) self.mods.alloc(data)
} }
fn push_link(&mut self, data: LinkData) -> LinkId { fn push_link(&mut self, data: LinkData) -> LinkId {
let owner = data.owner; let owner = data.owner;
let id = self.links.push(data); let id = self.links.alloc(data);
self.mods[owner].children.push(id); self.mods[owner].children.push(id);
id id
} }