#![cfg_attr(not(feature = "std"), no_std)] #![allow(dead_code)] // some code is tested for type checking only #[cfg(not(feature = "std"))] extern crate alloc; #[cfg(not(feature = "std"))] use alloc::{ borrow::Cow, string::{String, ToString}, }; #[cfg(feature = "std")] use std::borrow::Cow; use derive_more::From; use static_assertions::assert_not_impl_any; mod structs { use super::*; mod unit { use super::*; #[derive(Debug, From, PartialEq)] struct Unit; #[derive(Debug, From, PartialEq)] struct Tuple(); #[derive(Debug, From, PartialEq)] struct Struct {} #[test] fn assert() { assert_eq!(Unit, ().into()); assert_eq!(Tuple(), ().into()); assert_eq!(Struct {}, ().into()); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] struct Unit; #[derive(Debug, From, PartialEq)] struct Tuple(); #[derive(Debug, From, PartialEq)] struct Struct {} #[test] fn assert() { assert_eq!(Unit::<1>, ().into()); assert_eq!(Tuple::<1>(), ().into()); assert_eq!(Struct::<1> {}, ().into()); } } } mod single_field { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(i32); #[derive(Debug, From, PartialEq)] struct Struct { field: i32, } #[test] fn assert() { assert_eq!(Tuple(42), 42.into()); assert_eq!(Struct { field: 42 }, 42.into()); } mod types { use super::*; #[derive(Debug, From, PartialEq)] #[from(i8)] #[from(i16)] struct Tuple(i32); #[derive(Debug, From, PartialEq)] #[from(&str, Cow<'_, str>)] struct Struct { field: String, } #[test] fn assert() { assert_not_impl_any!(Tuple: From); assert_not_impl_any!(Struct: From); assert_eq!(Tuple(42), 42_i8.into()); assert_eq!(Tuple(42), 42_i16.into()); assert_eq!( Struct { field: "42".to_string(), }, "42".into(), ); assert_eq!( Struct { field: "42".to_string(), }, Cow::Borrowed("42").into(), ); } } mod forward { use super::*; #[derive(Debug, From, PartialEq)] #[from(forward)] struct Tuple(i32); #[derive(Debug, From, PartialEq)] #[from(forward)] struct Struct { field: String, } #[test] fn assert() { assert_eq!(Tuple(42), 42_i8.into()); assert_eq!(Tuple(42), 42_i16.into()); assert_eq!(Tuple(42), 42_i32.into()); assert_eq!( Struct { field: "42".to_string(), }, "42".into(), ); assert_eq!( Struct { field: "42".to_string(), }, Cow::Borrowed("42").into(), ); } } mod generic { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(T); #[derive(Debug, From, PartialEq)] struct Struct { field: T, } #[test] fn assert() { assert_eq!(Tuple(42), 42.into()); assert_eq!(Struct { field: 42 }, 42.into()); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple<'a, T>(&'a T); #[derive(Debug, From, PartialEq)] struct Struct<'a, T> { field: &'a T, } #[test] fn assert() { assert_eq!(Tuple(&42), (&42).into()); assert_eq!(Struct { field: &42 }, (&42).into()); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(&'static T); #[derive(Debug, From, PartialEq)] struct Struct { field: &'static T, } #[test] fn assert() { assert_eq!(Tuple(&42), (&42).into()); assert_eq!(Struct { field: &42 }, (&42).into()); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(T); #[derive(Debug, From, PartialEq)] struct Struct { field: T, } #[test] fn assert() { assert_eq!(Tuple(42), 42.into()); assert_eq!(Struct { field: 42 }, 42.into()); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(T); #[derive(Debug, From, PartialEq)] struct Struct { field: T, } #[test] fn assert() { assert_eq!(Tuple::<1, _>(1), 1.into()); assert_eq!(Struct::<_, 1> { field: 1 }, 1.into()); } } } } mod multi_field { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(i32, i16); #[derive(Debug, From, PartialEq)] struct Struct { field1: i32, field2: i16, } #[test] fn assert() { assert_eq!(Tuple(0, 1), (0, 1_i16).into()); assert_eq!( Struct { field1: 0, field2: 1, }, (0, 1_i16).into(), ); } mod types { use super::*; #[derive(Debug, From, PartialEq)] #[from((i16, i16))] struct Tuple(i32, i16); #[derive(Debug, From, PartialEq)] #[from((i16, i16))] struct Struct { field1: i32, field2: i16, } #[test] fn assert() { assert_not_impl_any!(Tuple: From<(i32, i16)>); assert_not_impl_any!(Struct: From<(i32, i16)>); assert_eq!(Tuple(0, 1), (0_i16, 1_i16).into()); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); } } mod forward { use super::*; #[derive(Debug, From, PartialEq)] #[from(forward)] struct Tuple(i32, i16); #[derive(Debug, From, PartialEq)] #[from(forward)] struct Struct { field1: i32, field2: i16, } #[test] fn assert() { assert_eq!(Tuple(0, 1), (0_i8, 1_i8).into()); assert_eq!(Tuple(0, 1), (0_i8, 1_i16).into()); assert_eq!(Tuple(0, 1), (0_i16, 1_i8).into()); assert_eq!(Tuple(0, 1), (0_i16, 1_i16).into()); assert_eq!(Tuple(0, 1), (0_i32, 1_i8).into()); assert_eq!(Tuple(0, 1), (0_i32, 1_i16).into()); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i8, 1_i8).into(), ); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i8, 1_i16).into(), ); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i16, 1_i8).into(), ); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i32, 1_i8).into(), ); assert_eq!( Struct { field1: 0, field2: 1 }, (0_i32, 1_i16).into(), ); } } mod generic { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(A, B); #[derive(Debug, From, PartialEq)] struct Struct { field1: A, field2: B, } #[test] fn assert() { assert_eq!(Tuple(1, 2_i8), (1, 2_i8).into()); assert_eq!( Struct { field1: 1, field2: 2_i8, }, (1, 2_i8).into(), ); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple<'a, A, B>(&'a A, &'a B); #[derive(Debug, From, PartialEq)] struct Struct<'a, A, B> { field1: &'a A, field2: &'a B, } #[test] fn assert() { assert_eq!(Tuple(&1, &2_i8), (&1, &2_i8).into()); assert_eq!( Struct { field1: &1, field2: &2_i8, }, (&1, &2_i8).into(), ); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] struct Tuple(A, B); #[derive(Debug, From, PartialEq)] struct Struct { field1: A, field2: B, } #[test] fn assert() { assert_eq!(Tuple(1, 2_i8), (1, 2_i8).into()); assert_eq!( Struct { field1: 1, field2: 2_i8, }, (1, 2_i8).into(), ); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] struct ConstTuple(A, B); #[derive(Debug, From, PartialEq)] struct ConstStruct { field1: A, field2: B, } #[test] fn assert() { assert_eq!(ConstTuple::<1, _, _>(1, 2_i8), (1, 2_i8).into()); assert_eq!( ConstStruct::<1, _, _> { field1: 1, field2: 2_i8, }, (1, 2_i8).into(), ); } } } } } mod enums { use super::*; mod unit_variant { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { #[from] Unit, Unnamed(), Named {}, } #[test] fn assert() { assert_eq!(Enum::Unit, ().into()); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] enum Unit { Variant, } #[derive(Debug, From, PartialEq)] enum Tuple { Variant(), } #[derive(Debug, From, PartialEq)] enum Struct { Variant {}, } assert_not_impl_any!(Unit: From<()>); assert_not_impl_any!(Tuple: From<()>); assert_not_impl_any!(Struct: From<()>); mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Unit { Variant, } #[derive(Debug, From, PartialEq)] enum Tuple { Variant(), } #[derive(Debug, From, PartialEq)] enum Struct { Variant {}, } assert_not_impl_any!(Unit<0>: From<()>); assert_not_impl_any!(Tuple<0>: From<()>); assert_not_impl_any!(Struct<0>: From<()>); } } mod from { use super::*; #[derive(Debug, From, PartialEq)] enum Unit { #[from] Variant, AutomaticallySkipped, } #[derive(Debug, From, PartialEq)] enum Tuple { #[from] Variant(), AutomaticallySkipped(), } #[derive(Debug, From, PartialEq)] enum Struct { #[from] Variant {}, AutomaticallySkipped {}, } #[test] fn assert() { assert_eq!(Unit::Variant, ().into()); assert_eq!(Tuple::Variant(), ().into()); assert_eq!(Struct::Variant {}, ().into()); } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Unit { #[from] Variant, } #[derive(Debug, From, PartialEq)] enum Tuple { #[from] Variant(), } #[derive(Debug, From, PartialEq)] enum Struct { #[from] Variant {}, } #[test] fn assert() { assert_eq!(Unit::<0>::Variant, ().into()); assert_eq!(Tuple::<0>::Variant(), ().into()); assert_eq!(Struct::<0>::Variant {}, ().into()); } } } } mod single_field_variant { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { Unnamed(i8), Named { field: i16 }, } #[test] fn assert() { assert_eq!(Enum::Unnamed(1), 1_i8.into()); assert_eq!(Enum::Named { field: 1 }, 1_i16.into()); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1), 1.into()); assert_eq!(Struct::Variant { field: 1 }, 1.into()); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, T> { Variant(&'a T), } #[derive(Debug, From, PartialEq)] enum Struct<'a, T> { Variant { field: &'a T }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1), (&1).into()); assert_eq!(Struct::Variant { field: &1 }, (&1).into()); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: &'static T }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1), (&1).into()); assert_eq!(Struct::Variant { field: &1 }, (&1).into()); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1), 1.into()); assert_eq!(Struct::Variant { field: 1 }, 1.into()); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T }, } #[test] fn assert() { assert_eq!(Tuple::Variant::<_, 1>(1), 1.into()); assert_eq!(Struct::Variant::<1, _> { field: 1 }, 1.into()); } } } mod from { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { #[from] Variant(i8), AutomaticallySkipped(i8), } #[derive(Debug, From, PartialEq)] enum Struct { #[from] Variant { field: i8, }, AutomaticallySkipped { field: i8, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1), 1_i8.into()); assert_eq!(Struct::Variant { field: 1 }, 1_i8.into()); } } mod skip { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { Unnamed(i8), #[from(skip)] UnnamedSkipped(i8), Named { field: i16, }, #[from(skip)] NamedSkipped { field: i16, }, } #[test] fn assert() { assert_eq!(Enum::Unnamed(1), 1_i8.into()); assert_eq!(Enum::Named { field: 1 }, 1_i16.into()); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1), 1.into()); assert_eq!(Struct::Variant { field: 1 }, 1.into()); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, T> { Variant(&'a T), #[from(skip)] Skipped(&'a T), } #[derive(Debug, From, PartialEq)] enum Struct<'a, T> { Variant { field: &'a T, }, #[from(skip)] Skipped { field: &'a T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1), (&1).into()); assert_eq!(Struct::Variant { field: &1 }, (&1).into()); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static T), #[from(skip)] Skipped(&'static T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: &'static T, }, #[from(skip)] Skipped { field: &'static T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1), (&1).into()); assert_eq!(Struct::Variant { field: &1 }, (&1).into()); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1), 1.into()); assert_eq!(Struct::Variant { field: 1 }, 1.into()); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(T), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: T, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::<_, 1>(1), 1.into()); assert_eq!(Struct::Variant::<1, _> { field: 1 }, 1.into()); } } mod concrete { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: i32, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::(1), 1.into()); assert_eq!(Struct::Variant:: { field: 1 }, 1.into()); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, T> { Variant(&'a i32), #[from(skip)] Skipped(&'a T), } #[derive(Debug, From, PartialEq)] enum Struct<'a, T> { Variant { field: &'a i32, }, #[from(skip)] Skipped { field: &'a T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::(&1), (&1).into()); assert_eq!( Struct::Variant:: { field: &1 }, (&1).into() ); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static i32), #[from(skip)] Skipped(&'static T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: &'static i32, }, #[from(skip)] Skipped { field: &'static T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::(&1), (&1).into()); assert_eq!( Struct::Variant:: { field: &1 }, (&1).into() ); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: i32, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::(1), 1.into()); assert_eq!(Struct::Variant:: { field: 1 }, 1.into()); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32), #[from(skip)] Skipped(T), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field: i32, }, #[from(skip)] Skipped { field: T, }, } #[test] fn assert() { assert_eq!(Tuple::Variant::(1), 1.into()); assert_eq!( Struct::Variant::<1, i32> { field: 1 }, 1.into() ); } } } } } mod types { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { #[from(i8)] Unnamed(i16), #[from(i16)] Named { field: i32, }, AutomaticallySkipped(i32), } #[test] fn assert() { assert_not_impl_any!(Enum: From); assert_eq!(Enum::Unnamed(1), 1_i8.into()); assert_eq!(Enum::Named { field: 1 }, 1_i16.into()); } } mod forward { use super::*; #[derive(Debug, From, PartialEq)] enum Unnamed { #[from(forward)] Variant(i32), AutomaticallyIgnored(i32), } #[derive(Debug, From, PartialEq)] enum Named { #[from(forward)] Variant { field: i32, }, AutomaticallyIgnored { field: i32, }, } #[test] fn assert() { assert_eq!(Unnamed::Variant(1), 1_i8.into()); assert_eq!(Unnamed::Variant(1), 1_i16.into()); assert_eq!(Unnamed::Variant(1), 1_i32.into()); assert_eq!(Named::Variant { field: 1 }, 1_i8.into()); assert_eq!(Named::Variant { field: 1 }, 1_i16.into()); assert_eq!(Named::Variant { field: 1 }, 1_i32.into()); } } } mod multi_field_variant { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { Tuple(i8, i8), Struct { field1: i16, field2: i16 }, } #[test] fn assert() { assert_eq!(Enum::Tuple(0, 1), (0_i8, 1_i8).into()); assert_eq!( Enum::Struct { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1, 2_i16), (1, 2_i16).into()); assert_eq!( Struct::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, A, B> { Variant(&'a A, &'a B), } #[derive(Debug, From, PartialEq)] enum Struct<'a, A, B> { Variant { field1: &'a A, field2: &'a B }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1, &2_i16), (&1, &2_i16).into()); assert_eq!( Struct::Variant { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static A, &'static B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: &'static A, field2: &'static B, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1, &2_i16), (&1, &2_i16).into()); assert_eq!( Struct::Variant { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1, 2_i16), (1, 2_i16).into()); assert_eq!( Struct::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B }, } #[test] fn assert() { assert_eq!(Tuple::Variant::<0, _, _>(1, 2_i16), (1, 2_i16).into()); assert_eq!( Struct::<_, 1, _>::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } } mod from { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { #[from] Variant(i8, i16), AutomaticallySkipped(i8, i16), } #[derive(Debug, From, PartialEq)] enum Struct { #[from] Variant { field1: i8, field2: i16, }, AutomaticallySkipped { field1: i8, field2: i16, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1, 2), (1_i8, 2_i16).into()); assert_eq!( Struct::Variant { field1: 1, field2: 2, }, (1_i8, 2_i16).into(), ); } } mod skip { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { Tuple(i8, i8), #[from(skip)] TupleSkipped(i8, i8), Struct { field1: i16, field2: i16, }, #[from(skip)] StructSkipped { field1: i16, field2: i16, }, } #[test] fn assert() { assert_eq!(Enum::Tuple(0, 1), (0_i8, 1_i8).into()); assert_eq!( Enum::Struct { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); } mod generic { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1, 2_i16), (1, 2_i16).into()); assert_eq!( Struct::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, A, B> { Variant(&'a A, &'a B), #[from(skip)] Skipped(&'a A, &'a B), } #[derive(Debug, From, PartialEq)] enum Struct<'a, A, B> { Variant { field1: &'a A, field2: &'a B, }, #[from(skip)] Skipped { field1: &'a A, field2: &'a B, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1, &2_i16), (&1, &2_i16).into()); assert_eq!( Struct::Variant { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static A, &'static B), #[from(skip)] Skipped(&'static A, &'static B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: &'static A, field2: &'static B, }, #[from(skip)] Skipped { field1: &'static A, field2: &'static B, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(&1, &2_i16), (&1, &2_i16).into()); assert_eq!( Struct::Variant { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!(Tuple::Variant(1, 2_i16), (1, 2_i16).into()); assert_eq!( Struct::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(A, B), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: A, field2: B, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::<0, _, _>(1, 2_i16), (1, 2_i16).into() ); assert_eq!( Struct::<_, 1, _>::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } mod concrete { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32, i16), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: i32, field2: i16, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::(1, 2_i16), (1, 2_i16).into(), ); assert_eq!( Struct::Variant:: { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } mod reference { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple<'a, A, B> { Variant(&'a i32, &'a i16), #[from(skip)] Skipped(&'a A, &'a B), } #[derive(Debug, From, PartialEq)] enum Struct<'a, A, B> { Variant { field1: &'a i32, field2: &'a i16, }, #[from(skip)] Skipped { field1: &'a A, field2: &'a B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::(&1, &2_i16), (&1, &2_i16).into(), ); assert_eq!( Struct::Variant:: { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod indirect { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(&'static i32, &'static i16), #[from(skip)] Skipped(&'static A, &'static B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: &'static i32, field2: &'static i16, }, #[from(skip)] Skipped { field1: &'static A, field2: &'static B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::(&1, &2_i16), (&1, &2_i16).into(), ); assert_eq!( Struct::Variant:: { field1: &1, field2: &2_i16, }, (&1, &2_i16).into(), ); } } mod bounded { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32, i16), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: i32, field2: i16, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::(1, 2_i16), (1, 2_i16).into(), ); assert_eq!( Struct::Variant:: { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } mod r#const { use super::*; #[derive(Debug, From, PartialEq)] enum Tuple { Variant(i32, i16), #[from(skip)] Skipped(A, B), } #[derive(Debug, From, PartialEq)] enum Struct { Variant { field1: i32, field2: i16, }, #[from(skip)] Skipped { field1: A, field2: B, }, } #[test] fn assert() { assert_eq!( Tuple::Variant::<0, i32, i16>(1, 2_i16), (1, 2_i16).into() ); assert_eq!( Struct::::Variant { field1: 1, field2: 2_i16, }, (1, 2_i16).into(), ); } } } } } mod types { use super::*; #[derive(Debug, From, PartialEq)] enum Enum { #[from((i8, i8))] Tuple(i16, i16), #[from((i16, i16))] Struct { field1: i32, field2: i32, }, AutomaticallySkipped { field1: i32, field2: i32, }, } #[test] fn assert() { assert_not_impl_any!(Enum: From<(i32, i32)>); assert_eq!(Enum::Tuple(0, 1), (0_i8, 1_i8).into()); assert_eq!( Enum::Struct { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); } } mod forward { use super::*; #[derive(Debug, From, PartialEq)] enum Unnamed { #[from(forward)] Variant(i16, i16), AutomaticallyIgnored(i16, i16), } #[derive(Debug, From, PartialEq)] enum Named { #[from(forward)] Variant { field1: i16, field2: i16, }, AutomaticallyIgnored { field1: i16, field2: i16, }, } #[test] fn assert() { assert_eq!(Unnamed::Variant(0, 1), (0_i8, 1_i8).into()); assert_eq!(Unnamed::Variant(0, 1), (0_i8, 1_i16).into()); assert_eq!(Unnamed::Variant(0, 1), (0_i16, 1_i8).into()); assert_eq!(Unnamed::Variant(0, 1), (0_i16, 1_i16).into()); assert_eq!( Named::Variant { field1: 0, field2: 1 }, (0_i8, 1_i8).into(), ); assert_eq!( Named::Variant { field1: 0, field2: 1 }, (0_i8, 1_i16).into(), ); assert_eq!( Named::Variant { field1: 0, field2: 1 }, (0_i16, 1_i8).into(), ); assert_eq!( Named::Variant { field1: 0, field2: 1 }, (0_i16, 1_i16).into(), ); } } } }