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#![allow(missing_docs, dead_code)]
#![cfg_attr(docsrs, feature(rustdoc_internals))]
use static_assertions::{assert_impl_one, assert_not_impl_any};
use variadics_please::all_tuples_enumerated;
trait Foo {}
macro_rules! foo {
($(#[$meta: meta])* $(($_: literal, $t: ident)),* $(,)?) => {
$(#[$meta])*
impl<$($t),*> Foo for ($($t,)*) {}
};
}
all_tuples_enumerated!(
#[doc(fake_variadic)]
foo,
0,
2,
T
);
all_tuples_enumerated!(/*no attribute here, since it's added before*/ foo, 4, 5, T);
trait Bar {}
macro_rules! bar {
($(#[$meta: meta])* $(($_: literal, $t1: ident, $t2: ident)),* $(,)?) => {
$(#[$meta])*
impl<$($t1,)* $($t2),*> Bar for ($(($t1, $t2),)*) {}
};
}
all_tuples_enumerated!(
#[doc(fake_variadic)]
bar,
0,
2,
T,
U
);
all_tuples_enumerated!(/*no attribute here, since it's added before*/ bar, 4, 5, T, U);
trait Baz {}
macro_rules! baz {
($(#[$meta: meta])* $(($_: literal, $t: ident)),* $(,)?) => {
$(#[$meta])*
impl<$($t),*> Baz for ($($t,)*) {}
};
}
// no {1}
all_tuples_enumerated!(
#[doc(fake_variadic)]
baz,
2,
3,
T
);
#[test]
fn basic_test() {
assert_impl_one!((): Foo);
assert_impl_one!(((),): Foo);
assert_impl_one!(((), ()): Foo);
assert_not_impl_any!(((), (), ()): Foo);
assert_impl_one!(((), (), (), ()): Foo);
assert_impl_one!(((), (), (), (), ()): Foo);
assert_not_impl_any!(((), (), (), (), (), ()): Foo);
assert_impl_one!((): Bar);
assert_impl_one!((((), ()),): Bar);
assert_impl_one!((((),()), ((),())): Bar);
assert_not_impl_any!((((),()), ((),()), ((),())): Bar);
assert_impl_one!((((),()), ((),()), ((),()), ((),())): Bar);
assert_impl_one!((((),()), ((),()), ((),()), ((),()), ((),())): Bar);
assert_not_impl_any!((((),()), ((),()), ((),()), ((),()), ((),()), ((),())): Bar);
// only impl for (T,) with `docsrs`
#[cfg(docsrs)]
assert_impl_one!(((),): Baz);
#[cfg(not(docsrs))]
assert_not_impl_any!(((),): Baz);
assert_impl_one!(((), ()): Baz);
assert_impl_one!(((), (), ()): Baz);
}