summaryrefslogtreecommitdiffstats
path: root/compiler/rustc_data_structures/src/sync/vec.rs
diff options
context:
space:
mode:
Diffstat (limited to 'compiler/rustc_data_structures/src/sync/vec.rs')
-rw-r--r--compiler/rustc_data_structures/src/sync/vec.rs68
1 files changed, 66 insertions, 2 deletions
diff --git a/compiler/rustc_data_structures/src/sync/vec.rs b/compiler/rustc_data_structures/src/sync/vec.rs
index cbea4f059..1783b4b35 100644
--- a/compiler/rustc_data_structures/src/sync/vec.rs
+++ b/compiler/rustc_data_structures/src/sync/vec.rs
@@ -2,7 +2,8 @@ use std::marker::PhantomData;
use rustc_index::vec::Idx;
-pub struct AppendOnlyVec<I: Idx, T: Copy> {
+#[derive(Default)]
+pub struct AppendOnlyIndexVec<I: Idx, T: Copy> {
#[cfg(not(parallel_compiler))]
vec: elsa::vec::FrozenVec<T>,
#[cfg(parallel_compiler)]
@@ -10,7 +11,7 @@ pub struct AppendOnlyVec<I: Idx, T: Copy> {
_marker: PhantomData<fn(&I)>,
}
-impl<I: Idx, T: Copy> AppendOnlyVec<I, T> {
+impl<I: Idx, T: Copy> AppendOnlyIndexVec<I, T> {
pub fn new() -> Self {
Self {
#[cfg(not(parallel_compiler))]
@@ -39,3 +40,66 @@ impl<I: Idx, T: Copy> AppendOnlyVec<I, T> {
return self.vec.get(i);
}
}
+
+#[derive(Default)]
+pub struct AppendOnlyVec<T: Copy> {
+ #[cfg(not(parallel_compiler))]
+ vec: elsa::vec::FrozenVec<T>,
+ #[cfg(parallel_compiler)]
+ vec: elsa::sync::LockFreeFrozenVec<T>,
+}
+
+impl<T: Copy> AppendOnlyVec<T> {
+ pub fn new() -> Self {
+ Self {
+ #[cfg(not(parallel_compiler))]
+ vec: elsa::vec::FrozenVec::new(),
+ #[cfg(parallel_compiler)]
+ vec: elsa::sync::LockFreeFrozenVec::new(),
+ }
+ }
+
+ pub fn push(&self, val: T) -> usize {
+ #[cfg(not(parallel_compiler))]
+ let i = self.vec.len();
+ #[cfg(not(parallel_compiler))]
+ self.vec.push(val);
+ #[cfg(parallel_compiler)]
+ let i = self.vec.push(val);
+ i
+ }
+
+ pub fn get(&self, i: usize) -> Option<T> {
+ #[cfg(not(parallel_compiler))]
+ return self.vec.get_copy(i);
+ #[cfg(parallel_compiler)]
+ return self.vec.get(i);
+ }
+
+ pub fn iter_enumerated(&self) -> impl Iterator<Item = (usize, T)> + '_ {
+ (0..)
+ .map(|i| (i, self.get(i)))
+ .take_while(|(_, o)| o.is_some())
+ .filter_map(|(i, o)| Some((i, o?)))
+ }
+
+ pub fn iter(&self) -> impl Iterator<Item = T> + '_ {
+ (0..).map(|i| self.get(i)).take_while(|o| o.is_some()).flatten()
+ }
+}
+
+impl<T: Copy + PartialEq> AppendOnlyVec<T> {
+ pub fn contains(&self, val: T) -> bool {
+ self.iter_enumerated().any(|(_, v)| v == val)
+ }
+}
+
+impl<A: Copy> FromIterator<A> for AppendOnlyVec<A> {
+ fn from_iter<T: IntoIterator<Item = A>>(iter: T) -> Self {
+ let this = Self::new();
+ for val in iter {
+ this.push(val);
+ }
+ this
+ }
+}