move more impls to common
This commit is contained in:
parent
b0ecfeb294
commit
eefbdafc16
@ -81,5 +81,58 @@ macro_rules! impl_common {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<T> From<[T; $size]> for $struct<T> {
|
||||||
|
fn from(from: [T; $size]) -> Self {
|
||||||
|
let mut iterator = from.into_iter();
|
||||||
|
|
||||||
|
Self {
|
||||||
|
// SAFETY: We know the size of `from` so `iterator.next()` is always `Some(..)`
|
||||||
|
$( $field: unsafe { iterator.next().unwrap_unchecked() } ), +
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: core::fmt::Debug> core::fmt::Debug for $struct<T> {
|
||||||
|
fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
|
||||||
|
let identifier = core::stringify!($struct);
|
||||||
|
|
||||||
|
f.debug_struct(identifier)
|
||||||
|
$( .field( core::stringify!($field), &self.$field ) ) +
|
||||||
|
.finish()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: PartialEq> PartialEq for $struct<T> {
|
||||||
|
fn eq(&self, other: &Self) -> bool {
|
||||||
|
$( self.$field == other.$field ) && +
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: Eq> Eq for $struct<T> { }
|
||||||
|
|
||||||
|
impl<T: core::hash::Hash> core::hash::Hash for $struct<T> {
|
||||||
|
fn hash<H: core::hash::Hasher>(&self, state: &mut H) {
|
||||||
|
$( self.$field.hash(state); ) +
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: Clone> Clone for $struct<T> {
|
||||||
|
fn clone(&self) -> Self {
|
||||||
|
Self {
|
||||||
|
$( $field: self.$field.clone() ), +
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: Copy> Copy for $struct<T> { }
|
||||||
|
|
||||||
|
impl<T: Default> Default for $struct<T> {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
$( $field: T::default() ), +
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,59 +5,6 @@ macro_rules! impl_vector {
|
|||||||
( $struct: ident { $($field: ident), + }, $size: expr ) => {
|
( $struct: ident { $($field: ident), + }, $size: expr ) => {
|
||||||
$crate::impl_common!($struct { $($field), + }, $size);
|
$crate::impl_common!($struct { $($field), + }, $size);
|
||||||
|
|
||||||
impl<T> From<[T; $size]> for $struct<T> {
|
|
||||||
fn from(from: [T; $size]) -> Self {
|
|
||||||
let mut iterator = from.into_iter();
|
|
||||||
|
|
||||||
Self {
|
|
||||||
// SAFETY: We know the size of `from` so `iterator.next()` is always `Some(..)`
|
|
||||||
$( $field: unsafe { iterator.next().unwrap_unchecked() } ), +
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: core::fmt::Debug> core::fmt::Debug for $struct<T> {
|
|
||||||
fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
|
|
||||||
let identifier = core::stringify!($struct);
|
|
||||||
|
|
||||||
f.debug_struct(identifier)
|
|
||||||
$( .field( core::stringify!($field), &self.$field ) ) +
|
|
||||||
.finish()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: PartialEq> PartialEq for $struct<T> {
|
|
||||||
fn eq(&self, other: &Self) -> bool {
|
|
||||||
$( self.$field == other.$field ) && +
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Eq> Eq for $struct<T> { }
|
|
||||||
|
|
||||||
impl<T: core::hash::Hash> core::hash::Hash for $struct<T> {
|
|
||||||
fn hash<H: core::hash::Hasher>(&self, state: &mut H) {
|
|
||||||
$( self.$field.hash(state); ) +
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Clone> Clone for $struct<T> {
|
|
||||||
fn clone(&self) -> Self {
|
|
||||||
Self {
|
|
||||||
$( $field: self.$field.clone() ), +
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Copy> Copy for $struct<T> { }
|
|
||||||
|
|
||||||
impl<T: Default> Default for $struct<T> {
|
|
||||||
fn default() -> Self {
|
|
||||||
Self {
|
|
||||||
$( $field: T::default() ), +
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Ord> $struct<T> {
|
impl<T: Ord> $struct<T> {
|
||||||
pub fn min(self, rhs: Self) -> $struct<T> {
|
pub fn min(self, rhs: Self) -> $struct<T> {
|
||||||
$struct{
|
$struct{
|
||||||
|
Loading…
Reference in New Issue
Block a user