From 7ec3cac7d6ed13aeaa80820258ecd5c27decbe41 Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Sat, 26 May 2018 09:48:50 -0700 Subject: [PATCH] Stabilize Deserialize for Box --- serde/build.rs | 6 ++++++ serde/src/de/impls.rs | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/serde/build.rs b/serde/build.rs index 28321278..391c5a2e 100644 --- a/serde/build.rs +++ b/serde/build.rs @@ -33,6 +33,12 @@ fn main() { Err(_) => return, }; + // CString::into_boxed_c_str stabilized in Rust 1.20: + // https://doc.rust-lang.org/std/ffi/struct.CString.html#method.into_boxed_c_str + if minor >= 20 { + println!("cargo:rustc-cfg=de_boxed_c_str"); + } + // 128-bit integers stabilized in Rust 1.26: // https://blog.rust-lang.org/2018/05/10/Rust-1.26.html if minor >= 26 { diff --git a/serde/src/de/impls.rs b/serde/src/de/impls.rs index fdade5b3..6d325883 100644 --- a/serde/src/de/impls.rs +++ b/serde/src/de/impls.rs @@ -573,7 +573,7 @@ macro_rules! forwarded_impl { } } -#[cfg(all(feature = "std", feature = "unstable"))] +#[cfg(all(feature = "std", de_boxed_c_str))] forwarded_impl!((), Box, CString::into_boxed_c_str); ////////////////////////////////////////////////////////////////////////////////