added vec versions of the fns
This commit is contained in:
55
src/lib.rs
55
src/lib.rs
@ -136,3 +136,58 @@ pub fn derive_http_response(input: TokenStream) -> TokenStream {
|
|||||||
|
|
||||||
TokenStream::from(expanded)
|
TokenStream::from(expanded)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[proc_macro_derive(SendVec)]
|
||||||
|
pub fn derive_send_vec(input: TokenStream) -> TokenStream {
|
||||||
|
let input = parse_macro_input!(input as DeriveInput);
|
||||||
|
let name = &input.ident;
|
||||||
|
|
||||||
|
let expanded = quote! {
|
||||||
|
impl #name {
|
||||||
|
/// Sends all items in the vec sequentially, awaiting each.
|
||||||
|
pub async fn send_vec(
|
||||||
|
items: Vec<Self>,
|
||||||
|
client: std::sync::Arc<awc::Client>,
|
||||||
|
headers: Option<Vec<(&str, &str)>>,
|
||||||
|
api_key: Option<&str>,
|
||||||
|
) -> Result<Vec<awc::ClientResponse>, awc::error::SendRequestError> {
|
||||||
|
let mut responses = Vec::with_capacity(items.len());
|
||||||
|
for item in items {
|
||||||
|
let resp = item.send(client.clone(), headers.clone(), api_key).await?;
|
||||||
|
responses.push(resp);
|
||||||
|
}
|
||||||
|
Ok(responses)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TokenStream::from(expanded)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[proc_macro_derive(ResponseVec)]
|
||||||
|
pub fn derive_response_vec(input: TokenStream) -> TokenStream {
|
||||||
|
let input = parse_macro_input!(input as DeriveInput);
|
||||||
|
let name = &input.ident;
|
||||||
|
|
||||||
|
let expanded = quote! {
|
||||||
|
impl #name {
|
||||||
|
/// Deserializes all responses sequentially into a Vec<Self>.
|
||||||
|
/// Assumes `Self` implements `DeserializeOwned`.
|
||||||
|
pub async fn response_vec(
|
||||||
|
responses: Vec<awc::ClientResponse>,
|
||||||
|
) -> Result<Vec<Self>, awc::error::JsonPayloadError>
|
||||||
|
where
|
||||||
|
Self: Sized + serde::de::DeserializeOwned,
|
||||||
|
{
|
||||||
|
let mut results = Vec::with_capacity(responses.len());
|
||||||
|
for resp in responses {
|
||||||
|
let item = resp.json::<Self>().await?;
|
||||||
|
results.push(item);
|
||||||
|
}
|
||||||
|
Ok(results)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TokenStream::from(expanded)
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user