diff --git a/serde_derive/src/de.rs b/serde_derive/src/de.rs index 44ed7fa0..71326b84 100644 --- a/serde_derive/src/de.rs +++ b/serde_derive/src/de.rs @@ -203,7 +203,9 @@ impl BorrowedLifetimes { fn borrowed_lifetimes(cont: &Container) -> BorrowedLifetimes { let mut lifetimes = BTreeSet::new(); for field in cont.body.all_fields() { - lifetimes.extend(field.attrs.borrowed_lifetimes().iter().cloned()); + if !field.attrs.skip_deserializing() { + lifetimes.extend(field.attrs.borrowed_lifetimes().iter().cloned()); + } } if lifetimes.iter().any(|b| b.ident == "'static") { BorrowedLifetimes::Static diff --git a/test_suite/tests/test_gen.rs b/test_suite/tests/test_gen.rs index f9143099..50cd13b7 100644 --- a/test_suite/tests/test_gen.rs +++ b/test_suite/tests/test_gen.rs @@ -511,6 +511,14 @@ fn test_gen() { Tuple(&'a str, &'static str), Newtype(&'static str), } + + #[derive(Serialize, Deserialize)] + struct SkippedStaticStr { + #[serde(skip_deserializing)] + skipped: &'static str, + other: isize, + } + assert::(); } //////////////////////////////////////////////////////////////////////////