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
#![allow(nonstandard_style, unused_imports)]
extern crate proc_macro;
use ::core::ops::Not as _;
use ::proc_macro::TokenStream;
use ::proc_macro2::{
Span,
TokenStream as TokenStream2,
};
use ::quote::{
format_ident,
quote,
quote_spanned,
ToTokens,
};
use ::syn::{*,
parse::{Parse, Parser, ParseStream},
punctuated::Punctuated,
spanned::Spanned,
visit_mut::VisitMut,
Result,
};
use self::collect_lifetime_params::*;
mod collect_lifetime_params;
use self::manually_desugar_async::*;
mod manually_desugar_async;
use self::append_captures_hack_to_impl_occurrences::*;
mod append_captures_hack_to_impl_occurrences;
#[proc_macro_attribute] pub
fn fix_hidden_lifetime_bug (
attrs: TokenStream,
input: TokenStream,
) -> TokenStream
{
let _: parse::Nothing = parse_macro_input!(attrs);
match parse_macro_input!(input) {
| Item::Fn(ItemFn {
attrs, vis, sig, block,
}) => {
let fun = ImplItemMethod {
attrs, vis, sig, block: *block,
defaultness: None,
};
fix_fn(fun)
},
| _ => Err(Error::new(Span::call_site(), concat!(
"expected ",
"`fn`",
".",
))),
}
.unwrap_or_else(|err| err.to_compile_error())
.into()
}
fn fix_fn (mut fun: ImplItemMethod)
-> Result<TokenStream2>
{
let lifetimes = collect_lifetime_params(&mut fun.sig);
if fun.sig.asyncness.is_some() {
fun = manually_desugar_async(fun, &lifetimes);
}
append_captures_hack_to_impl_occurrences(
&lifetimes,
&mut fun.sig.output,
);
Ok(fun.into_token_stream())
}