Skip to content

Commit

Permalink
Merge pull request #2847 from dtolnay/newtypewith
Browse files Browse the repository at this point in the history
Hygiene for macro-generated newtype struct deserialization with `with` attr
  • Loading branch information
dtolnay authored Oct 22, 2024
2 parents 49e11ce + 79925ac commit ef0ed22
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 3 deletions.
7 changes: 4 additions & 3 deletions serde_derive/src/de.rs
Original file line number Diff line number Diff line change
Expand Up @@ -875,13 +875,14 @@ fn deserialize_newtype_struct(
) -> TokenStream {
let delife = params.borrowed.de_lifetime();
let field_ty = field.ty;
let deserializer_var = quote!(__e);

let value = match field.attrs.deserialize_with() {
None => {
let span = field.original.span();
let func = quote_spanned!(span=> <#field_ty as _serde::Deserialize>::deserialize);
quote! {
#func(__e)?
#func(#deserializer_var)?
}
}
Some(path) => {
Expand All @@ -890,7 +891,7 @@ fn deserialize_newtype_struct(
// on the #[serde(with = "...")]
// ^^^^^
quote_spanned! {path.span()=>
#path(__e)?
#path(#deserializer_var)?
}
}
};
Expand All @@ -906,7 +907,7 @@ fn deserialize_newtype_struct(

quote! {
#[inline]
fn visit_newtype_struct<__E>(self, __e: __E) -> _serde::__private::Result<Self::Value, __E::Error>
fn visit_newtype_struct<__E>(self, #deserializer_var: __E) -> _serde::__private::Result<Self::Value, __E::Error>
where
__E: _serde::Deserializer<#delife>,
{
Expand Down
27 changes: 27 additions & 0 deletions test_suite/tests/regression/issue2846.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
#![allow(clippy::trivially_copy_pass_by_ref)]

use serde_derive::Deserialize;

macro_rules! declare_in_macro {
($with:literal) => {
#[derive(Deserialize)]
pub struct S(
#[serde(with = $with)]
#[allow(dead_code)]
i32,
);
};
}

declare_in_macro!("with");

mod with {
use serde::Deserializer;

pub fn deserialize<'de, D>(_: D) -> Result<i32, D::Error>
where
D: Deserializer<'de>,
{
unimplemented!()
}
}

0 comments on commit ef0ed22

Please sign in to comment.