Adjust with the latest teloxide

This commit is contained in:
Temirkhan Myrzamadi 2021-03-06 03:07:35 +06:00
parent cbb1f39e7b
commit 6fc7e7d804
2 changed files with 15 additions and 4 deletions

View file

@ -2,6 +2,6 @@ format_code_in_doc_comments = true
wrap_comments = true wrap_comments = true
format_strings = true format_strings = true
max_width = 80 max_width = 80
merge_imports = true imports_granularity = "Crate"
use_small_heuristics = "Max" use_small_heuristics = "Max"
use_field_init_shorthand = true use_field_init_shorthand = true

View file

@ -77,6 +77,13 @@ pub fn teloxide(attr: TokenStream, item: TokenStream) -> TokenStream {
type>" type>"
), ),
}; };
let requester_param_type = match params
.get(1)
.expect("A requester parameter must be specified")
{
FnArg::Typed(typed) => typed.ty.clone(),
_ => unreachable!(),
};
let aux_param_type = match params.get(2) { let aux_param_type = match params.get(2) {
Some(data_param_type) => match *data_param_type { Some(data_param_type) => match *data_param_type {
FnArg::Typed(typed) => typed.ty.clone(), FnArg::Typed(typed) => typed.ty.clone(),
@ -101,8 +108,9 @@ pub fn teloxide(attr: TokenStream, item: TokenStream) -> TokenStream {
type Aux = #aux_param_type; type Aux = #aux_param_type;
type Dialogue = <#fn_return_type as teloxide::dispatching::dialogue::SubtransitionOutputType>::Output; type Dialogue = <#fn_return_type as teloxide::dispatching::dialogue::SubtransitionOutputType>::Output;
type Error = <#fn_return_type as teloxide::dispatching::dialogue::SubtransitionOutputType>::Error; type Error = <#fn_return_type as teloxide::dispatching::dialogue::SubtransitionOutputType>::Error;
type Requester = <#requester_param_type as teloxide::dispatching::UpdateWithCxRequesterType>::Requester;
fn react(self, cx: teloxide::dispatching::dialogue::TransitionIn, aux: #aux_param_type) fn react(self, cx: teloxide::dispatching::dialogue::TransitionIn<Self::Requester>, aux: #aux_param_type)
-> futures::future::BoxFuture<'static, #fn_return_type> { -> futures::future::BoxFuture<'static, #fn_return_type> {
#item #item
futures::future::FutureExt::boxed(#call_fn) futures::future::FutureExt::boxed(#call_fn)
@ -152,8 +160,11 @@ pub fn derive_transition(item: TokenStream) -> TokenStream {
"impl teloxide::dispatching::dialogue::Transition for {1} {{type Aux \ "impl teloxide::dispatching::dialogue::Transition for {1} {{type Aux \
= <{0} as teloxide::dispatching::dialogue::Subtransition>::Aux;type \ = <{0} as teloxide::dispatching::dialogue::Subtransition>::Aux;type \
Error = <{0} as \ Error = <{0} as \
teloxide::dispatching::dialogue::Subtransition>::Error;fn \ teloxide::dispatching::dialogue::Subtransition>::Error;type \
react(self, cx: teloxide::dispatching::dialogue::TransitionIn, aux: \ Requester = <{0} as \
teloxide::dispatching::dialogue::Subtransition>::Requester;fn \
react(self, cx: \
teloxide::dispatching::dialogue::TransitionIn<Self::Requester>, aux: \
Self::Aux) -> futures::future::BoxFuture<'static, \ Self::Aux) -> futures::future::BoxFuture<'static, \
teloxide::dispatching::dialogue::TransitionOut<Self, Self::Error>> \ teloxide::dispatching::dialogue::TransitionOut<Self, Self::Error>> \
{{ futures::future::FutureExt::boxed(async move {{ match self {{", {{ futures::future::FutureExt::boxed(async move {{ match self {{",