pub trait IndividualLocation {
fn get_slice(&self) -> &[crate::Location];
}
macro_rules! impl_individual_location {
($for: ty, $self_:ident,$body: expr) => {
impl IndividualLocation for $for {
fn get_slice(&$self_) -> &[crate::Location] {
$body
}
}
};
($n: ident, $nty: ty, $for: ty, $self_:ident,$body: expr) => {
impl<const $n: $nty> IndividualLocation for $for {
fn get_slice(&$self_) -> &[crate::Location] {
$body
}
}
};
}
impl_individual_location!(
Option<&[crate::Location]>,
self,
match self {
Some(s) => s,
None => &[],
}
);
impl_individual_location!(&[crate::Location], self, self);
impl_individual_location!(&Vec<crate::Location>, self, self.as_slice());
impl_individual_location!(Vec<crate::Location>, self, self.as_slice());
impl_individual_location!(&[f64], self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::Location, self.len())
});
impl_individual_location!(&Vec<f64>, self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::Location, self.len())
});
impl_individual_location!(Vec<f64>, self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::Location, self.len())
});
impl_individual_location!(N, usize, &[f64; N], self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::Location, self.len())
});
impl_individual_location!(N, usize, [f64; N], self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::Location, self.len())
});
impl_individual_location!(N, usize, &[crate::Location; N], self, self.as_slice());
impl_individual_location!(N, usize, [crate::Location; N], self, self.as_slice());
pub trait IndividualParents {
fn get_slice(&self) -> &[crate::IndividualId];
}
macro_rules! impl_individual_parents {
($for: ty, $self_:ident,$body: expr) => {
impl IndividualParents for $for {
fn get_slice(&$self_) -> &[crate::IndividualId] {
$body
}
}
};
($n: ident, $nty: ty, $for: ty, $self_:ident,$body: expr) => {
impl<const $n: $nty> IndividualParents for $for {
fn get_slice(&$self_) -> &[crate::IndividualId] {
$body
}
}
};
}
impl_individual_parents!(
Option<&[crate::IndividualId]>,
self,
match self {
Some(s) => s,
None => &[],
}
);
impl_individual_parents!(&[crate::IndividualId], self, self);
impl_individual_parents!(&Vec<crate::IndividualId>, self, self.as_slice());
impl_individual_parents!(Vec<crate::IndividualId>, self, self.as_slice());
impl_individual_parents!(&[crate::sys::bindings::tsk_id_t], self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::IndividualId, self.len())
});
impl_individual_parents!(&Vec<crate::sys::bindings::tsk_id_t>, self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::IndividualId, self.len())
});
impl_individual_parents!(Vec<crate::sys::bindings::tsk_id_t>, self, unsafe {
std::slice::from_raw_parts(self.as_ptr() as *const crate::IndividualId, self.len())
});
impl_individual_parents!(
N,
usize,
&[crate::sys::bindings::tsk_id_t; N],
self,
unsafe { std::slice::from_raw_parts(self.as_ptr() as *const crate::IndividualId, self.len()) }
);
impl_individual_parents!(
N,
usize,
[crate::sys::bindings::tsk_id_t; N],
self,
unsafe { std::slice::from_raw_parts(self.as_ptr() as *const crate::IndividualId, self.len()) }
);
impl_individual_parents!(N, usize, &[crate::IndividualId; N], self, self.as_slice());
impl_individual_parents!(N, usize, [crate::IndividualId; N], self, self.as_slice());
mod private {
pub trait NewTypeMarker: TryInto<usize, Error = crate::TskitError> {}
pub trait TableColumnMarker {}
}
impl private::NewTypeMarker for crate::EdgeId {}
impl private::NewTypeMarker for crate::NodeId {}
impl private::NewTypeMarker for crate::SiteId {}
impl private::NewTypeMarker for crate::MutationId {}
impl private::NewTypeMarker for crate::MigrationId {}
impl private::NewTypeMarker for crate::IndividualId {}
impl private::NewTypeMarker for crate::PopulationId {}
#[cfg(feature = "provenance")]
#[cfg_attr(doc_cfg, doc(cfg(feature = "provenance")))]
impl private::NewTypeMarker for crate::ProvenanceId {}
pub trait TableColumn<I, T>:
std::ops::Index<I, Output = T>
+ std::ops::Index<usize, Output = T>
+ std::ops::Index<crate::SizeType, Output = T>
+ private::TableColumnMarker
{
fn as_slice(&self) -> &[T];
fn get_with_id(&self, at: I) -> Option<&T>;
fn get(&self, at: usize) -> Option<&T> {
self.as_slice().get(at)
}
fn get_with_size_type(&self, at: crate::SizeType) -> Option<&T> {
self.as_slice().get(usize::try_from(at).ok()?)
}
fn iter<'a, 'b>(&'a self) -> impl Iterator<Item = &'b T>
where
'a: 'b,
T: 'b,
{
self.as_slice().iter()
}
fn len(&self) -> usize {
self.as_slice().len()
}
fn is_empty(&self) -> bool {
self.as_slice().is_empty()
}
}
impl<T> private::TableColumnMarker for crate::table_column::OpaqueTableColumn<'_, T> {}
impl<I, T> std::ops::Index<I> for crate::table_column::OpaqueTableColumn<'_, T>
where
I: private::NewTypeMarker,
{
type Output = T;
fn index(&self, index: I) -> &Self::Output {
&self.0[index.try_into().unwrap()]
}
}
impl<I, T> TableColumn<I, T> for crate::table_column::OpaqueTableColumn<'_, T>
where
I: private::NewTypeMarker,
{
fn as_slice(&self) -> &[T] {
self.0
}
fn get_with_id(&self, at: I) -> Option<&T> {
self.0.get(at.try_into().ok()?)
}
}