1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
#![cfg_attr(not(feature = "std"), no_std)]
#![allow(dead_code)]
use derive_more::Unwrap;
#[derive(Unwrap)]
enum Either<TLeft, TRight> {
Left(TLeft),
Right(TRight),
}
#[derive(Unwrap)]
#[derive(Debug)]
#[unwrap(ref, ref_mut)]
enum Maybe<T> {
Nothing,
Just(T),
}
#[derive(Unwrap)]
enum Color {
RGB(u8, u8, u8),
CMYK(u8, u8, u8, u8),
}
/// With lifetime
#[derive(Unwrap)]
enum Nonsense<'a, T> {
Ref(&'a T),
NoRef,
#[unwrap(ignore)]
NoRefIgnored,
}
#[derive(Unwrap)]
enum WithConstraints<T>
where
T: Copy,
{
One(T),
Two,
}
#[derive(Unwrap)]
enum KitchenSink<'a, 'b, T1: Copy, T2: Clone>
where
T2: Into<T1> + 'b,
{
Left(&'a T1),
Right(&'b T2),
OwnBoth(T1, T2),
Empty,
NeverMind(),
NothingToSeeHere(),
}
/// Single variant enum
#[derive(Unwrap)]
enum Single {
Value(i32),
}
#[derive(Unwrap)]
#[derive(Debug, PartialEq)]
#[unwrap(ref, ref_mut)]
enum Tuple<T> {
None,
Single(T),
Double(T, T),
Triple(T, T, T),
}
#[test]
pub fn test_unwrap() {
assert_eq!(Maybe::<()>::Nothing.unwrap_nothing(), ());
assert_eq!(Maybe::Just(1).unwrap_just(), 1);
assert_eq!((&Maybe::Just(42)).unwrap_just_ref(), &42);
assert_eq!((&mut Maybe::Just(42)).unwrap_just_mut(), &mut 42);
}
#[test]
#[should_panic]
pub fn test_unwrap_panic_1() {
Maybe::<()>::Nothing.unwrap_just();
}
#[test]
#[should_panic]
pub fn test_unwrap_panic_2() {
Maybe::Just(2).unwrap_nothing();
}
#[test]
#[should_panic]
pub fn test_unwrap_ref_panic() {
Maybe::Just(2).unwrap_nothing_ref();
}
#[test]
pub fn test_unwrap_mut_1() {
let mut value = Tuple::Double(1, 12);
let (a, b) = value.unwrap_double_mut();
*a = 9;
*b = 10;
assert_eq!(value, Tuple::Double(9, 10))
}
#[test]
pub fn test_unwrap_mut_2() {
let mut value = Tuple::Single(128);
let x = value.unwrap_single_mut();
*x *= 2;
assert_eq!(value, Tuple::Single(256));
}
|