Fix some mistakes + new doc
This commit is contained in:
parent
1bf3aee381
commit
ee8510e4e1
@ -17,15 +17,13 @@ use crate::{Idx, IndexSlice};
|
||||
/// While it's possible to use `u32` or `usize` directly for `I`,
|
||||
/// you almost certainly want to use a [`newtype_index!`]-generated type instead.
|
||||
///
|
||||
/// This allows to index the IndexVec with the new index type
|
||||
///
|
||||
///
|
||||
/// This allows to index the IndexVec with the new index type.
|
||||
/// [`newtype_index!`]: ../macro.newtype_index.html
|
||||
#[derive(Clone, PartialEq, Eq, Hash)]
|
||||
#[repr(transparent)]
|
||||
pub struct IndexVec<I: Idx, T> {
|
||||
pub raw: Vec<T>,
|
||||
_marker: PhantomData<I>,
|
||||
_marker: PhantomData<fn(&I)>,
|
||||
}
|
||||
|
||||
impl<I: Idx, T> IndexVec<I, T> {
|
||||
@ -35,7 +33,7 @@ impl<I: Idx, T> IndexVec<I, T> {
|
||||
IndexVec::from_raw(Vec::new())
|
||||
}
|
||||
|
||||
/// Constructs a new `IndexVec<I, T>` from a `Vec<T>`
|
||||
/// Constructs a new `IndexVec<I, T>` from a `Vec<T>`.
|
||||
#[inline]
|
||||
pub const fn from_raw(raw: Vec<T>) -> Self {
|
||||
IndexVec { raw, _marker: PhantomData }
|
||||
@ -65,7 +63,7 @@ impl<I: Idx, T> IndexVec<I, T> {
|
||||
IndexVec::from_raw(vec![elem; universe.len()])
|
||||
}
|
||||
|
||||
/// Creates a new IndexVec
|
||||
/// Creates a new IndexVec with n copies of the `elem`.
|
||||
#[inline]
|
||||
pub fn from_elem_n(elem: T, n: usize) -> Self
|
||||
where
|
||||
@ -92,6 +90,7 @@ impl<I: Idx, T> IndexVec<I, T> {
|
||||
IndexSlice::from_raw_mut(&mut self.raw)
|
||||
}
|
||||
|
||||
/// Pushes an element to the array returning the index where it was pushed to.
|
||||
#[inline]
|
||||
pub fn push(&mut self, d: T) -> I {
|
||||
let idx = self.next_index();
|
||||
|
Loading…
x
Reference in New Issue
Block a user