From b01c23b5ee3ba96c286b22fb8f958ea6b2576fde Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Wed, 11 Jan 2017 11:34:47 -0800 Subject: [PATCH] Also provide a smarter alternative for the other impossible case --- serde_codegen/src/de.rs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/serde_codegen/src/de.rs b/serde_codegen/src/de.rs index af2af257d..9e0b6bee9 100644 --- a/serde_codegen/src/de.rs +++ b/serde_codegen/src/de.rs @@ -533,6 +533,9 @@ fn deserialize_item_enum( // This is an empty enum like `enum Impossible {}` or an enum in which // all variants have `#[serde(skip_deserializing)]`. quote! { + // FIXME: Once we drop support for Rust 1.15: + // let Err(err) = visitor.visit_variant::<__Field>(); + // Err(err) visitor.visit_variant::<__Field>().map(|impossible| match impossible {}) } } else { @@ -749,7 +752,7 @@ fn deserialize_map( ) -> Tokens { if fields.is_empty() && item_attrs.deny_unknown_fields() { return quote! { - // Once we drop support for Rust 1.15: + // FIXME: Once we drop support for Rust 1.15: // let None::<__Field> = try!(visitor.visit_key()); try!(visitor.visit_key::<__Field>()).map(|impossible| match impossible {}); try!(visitor.end());