mirror of
https://github.com/pezkuwichain/serde.git
synced 2026-04-29 03:47:55 +00:00
Compare commits
23 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 9b868ef831 | |||
| c3eaf76430 | |||
| 32958dec3b | |||
| d64a97ba1e | |||
| c3df3372a1 | |||
| 8764353fe2 | |||
| e08c5de5dd | |||
| bc5af506bd | |||
| 28a092261b | |||
| 18dcae0a77 | |||
| 58c307f9cc | |||
| 8cc4809414 | |||
| 1179158def | |||
| 91aa40e749 | |||
| 595019e979 | |||
| b0d7917f88 | |||
| 8e6637a1e4 | |||
| 694fe05953 | |||
| f3dfd2a237 | |||
| 9e6158e9e6 | |||
| d577c4a2ce | |||
| fee0b82a40 | |||
| 7aafa26314 |
@@ -84,6 +84,7 @@ jobs:
|
|||||||
- uses: dtolnay/rust-toolchain@master
|
- uses: dtolnay/rust-toolchain@master
|
||||||
with:
|
with:
|
||||||
toolchain: ${{matrix.rust}}
|
toolchain: ${{matrix.rust}}
|
||||||
|
- run: sed -i '/"test_suite"/d' Cargo.toml
|
||||||
- run: cd serde && cargo build --features rc
|
- run: cd serde && cargo build --features rc
|
||||||
- run: cd serde && cargo build --no-default-features
|
- run: cd serde && cargo build --no-default-features
|
||||||
- run: cd serde && cargo build
|
- run: cd serde && cargo build
|
||||||
@@ -95,6 +96,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
- uses: dtolnay/rust-toolchain@1.56.0
|
- uses: dtolnay/rust-toolchain@1.56.0
|
||||||
|
- run: sed -i '/"test_suite"/d' Cargo.toml
|
||||||
- run: cd serde && cargo check --no-default-features
|
- run: cd serde && cargo check --no-default-features
|
||||||
- run: cd serde && cargo check
|
- run: cd serde && cargo check
|
||||||
- run: cd serde_derive && cargo check
|
- run: cd serde_derive && cargo check
|
||||||
@@ -106,6 +108,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
- uses: dtolnay/rust-toolchain@1.36.0
|
- uses: dtolnay/rust-toolchain@1.36.0
|
||||||
|
- run: sed -i '/"test_suite"/d' Cargo.toml
|
||||||
- run: cd serde && cargo build --no-default-features --features alloc
|
- run: cd serde && cargo build --no-default-features --features alloc
|
||||||
|
|
||||||
minimal:
|
minimal:
|
||||||
|
|||||||
+2
-2
@@ -46,8 +46,8 @@ fn main() {
|
|||||||
Serde is one of the most widely used Rust libraries so any place that Rustaceans
|
Serde is one of the most widely used Rust libraries so any place that Rustaceans
|
||||||
congregate will be able to help you out. For chat, consider trying the
|
congregate will be able to help you out. For chat, consider trying the
|
||||||
[#rust-questions] or [#rust-beginners] channels of the unofficial community
|
[#rust-questions] or [#rust-beginners] channels of the unofficial community
|
||||||
Discord (invite: <https://discord.gg/rust-lang-community>, the [#rust-usage] or
|
Discord (invite: <https://discord.gg/rust-lang-community>), the [#rust-usage]
|
||||||
[#beginners] channels of the official Rust Project Discord (invite:
|
or [#beginners] channels of the official Rust Project Discord (invite:
|
||||||
<https://discord.gg/rust-lang>), or the [#general][zulip] stream in Zulip. For
|
<https://discord.gg/rust-lang>), or the [#general][zulip] stream in Zulip. For
|
||||||
asynchronous, consider the [\[rust\] tag on StackOverflow][stackoverflow], the
|
asynchronous, consider the [\[rust\] tag on StackOverflow][stackoverflow], the
|
||||||
[/r/rust] subreddit which has a pinned weekly easy questions post, or the Rust
|
[/r/rust] subreddit which has a pinned weekly easy questions post, or the Rust
|
||||||
|
|||||||
+2
-2
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "serde"
|
name = "serde"
|
||||||
version = "1.0.203"
|
version = "1.0.205"
|
||||||
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
|
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
categories = ["encoding", "no-std", "no-std::no-alloc"]
|
categories = ["encoding", "no-std", "no-std::no-alloc"]
|
||||||
@@ -37,7 +37,7 @@ rustdoc-args = ["--generate-link-to-definition"]
|
|||||||
# is compatible with exactly one serde release because the generated code
|
# is compatible with exactly one serde release because the generated code
|
||||||
# involves nonpublic APIs which are not bound by semver.
|
# involves nonpublic APIs which are not bound by semver.
|
||||||
[target.'cfg(any())'.dependencies]
|
[target.'cfg(any())'.dependencies]
|
||||||
serde_derive = { version = "=1.0.203", path = "../serde_derive" }
|
serde_derive = { version = "=1.0.205", path = "../serde_derive" }
|
||||||
|
|
||||||
|
|
||||||
### FEATURES #################################################################
|
### FEATURES #################################################################
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ fn main() {
|
|||||||
println!("cargo:rustc-check-cfg=cfg(no_core_cstr)");
|
println!("cargo:rustc-check-cfg=cfg(no_core_cstr)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(no_core_num_saturating)");
|
println!("cargo:rustc-check-cfg=cfg(no_core_num_saturating)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(no_core_try_from)");
|
println!("cargo:rustc-check-cfg=cfg(no_core_try_from)");
|
||||||
|
println!("cargo:rustc-check-cfg=cfg(no_diagnostic_namespace)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(no_float_copysign)");
|
println!("cargo:rustc-check-cfg=cfg(no_float_copysign)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(no_num_nonzero_signed)");
|
println!("cargo:rustc-check-cfg=cfg(no_num_nonzero_signed)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(no_relaxed_trait_bounds)");
|
println!("cargo:rustc-check-cfg=cfg(no_relaxed_trait_bounds)");
|
||||||
@@ -84,6 +85,12 @@ fn main() {
|
|||||||
if minor < 74 {
|
if minor < 74 {
|
||||||
println!("cargo:rustc-cfg=no_core_num_saturating");
|
println!("cargo:rustc-cfg=no_core_num_saturating");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Support for the `#[diagnostic]` tool attribute namespace
|
||||||
|
// https://blog.rust-lang.org/2024/05/02/Rust-1.78.0.html#diagnostic-attributes
|
||||||
|
if minor < 78 {
|
||||||
|
println!("cargo:rustc-cfg=no_diagnostic_namespace");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn rustc_minor_version() -> Option<u32> {
|
fn rustc_minor_version() -> Option<u32> {
|
||||||
|
|||||||
@@ -532,6 +532,13 @@ impl<'a> Display for Expected + 'a {
|
|||||||
/// deserializer lifetimes] for a more detailed explanation of these lifetimes.
|
/// deserializer lifetimes] for a more detailed explanation of these lifetimes.
|
||||||
///
|
///
|
||||||
/// [Understanding deserializer lifetimes]: https://serde.rs/lifetimes.html
|
/// [Understanding deserializer lifetimes]: https://serde.rs/lifetimes.html
|
||||||
|
#[cfg_attr(
|
||||||
|
not(no_diagnostic_namespace),
|
||||||
|
diagnostic::on_unimplemented(
|
||||||
|
note = "for local types consider adding `#[derive(serde::Deserialize)]` to your `{Self}` type",
|
||||||
|
note = "for types from other crates check whether the crate offers a `serde` feature flag",
|
||||||
|
)
|
||||||
|
)]
|
||||||
pub trait Deserialize<'de>: Sized {
|
pub trait Deserialize<'de>: Sized {
|
||||||
/// Deserialize this value from the given Serde deserializer.
|
/// Deserialize this value from the given Serde deserializer.
|
||||||
///
|
///
|
||||||
|
|||||||
+2
-2
@@ -95,7 +95,7 @@
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Serde types in rustdoc of other crates get linked to here.
|
// Serde types in rustdoc of other crates get linked to here.
|
||||||
#![doc(html_root_url = "https://docs.rs/serde/1.0.203")]
|
#![doc(html_root_url = "https://docs.rs/serde/1.0.205")]
|
||||||
// Support using Serde without the standard library!
|
// Support using Serde without the standard library!
|
||||||
#![cfg_attr(not(feature = "std"), no_std)]
|
#![cfg_attr(not(feature = "std"), no_std)]
|
||||||
// Show which crate feature enables conditionally compiled APIs in documentation.
|
// Show which crate feature enables conditionally compiled APIs in documentation.
|
||||||
@@ -105,7 +105,7 @@
|
|||||||
// discussion of these features please refer to this issue:
|
// discussion of these features please refer to this issue:
|
||||||
//
|
//
|
||||||
// https://github.com/serde-rs/serde/issues/812
|
// https://github.com/serde-rs/serde/issues/812
|
||||||
#![cfg_attr(feature = "unstable", feature(error_in_core, never_type))]
|
#![cfg_attr(feature = "unstable", feature(never_type))]
|
||||||
#![allow(unknown_lints, bare_trait_objects, deprecated)]
|
#![allow(unknown_lints, bare_trait_objects, deprecated)]
|
||||||
// Ignored clippy and clippy_pedantic lints
|
// Ignored clippy and clippy_pedantic lints
|
||||||
#![allow(
|
#![allow(
|
||||||
|
|||||||
@@ -1125,8 +1125,7 @@ where
|
|||||||
where
|
where
|
||||||
T: ?Sized + Serialize,
|
T: ?Sized + Serialize,
|
||||||
{
|
{
|
||||||
tri!(self.0.serialize_key(variant));
|
self.0.serialize_entry(variant, value)
|
||||||
self.0.serialize_value(value)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn serialize_seq(self, _: Option<usize>) -> Result<Self::SerializeSeq, Self::Error> {
|
fn serialize_seq(self, _: Option<usize>) -> Result<Self::SerializeSeq, Self::Error> {
|
||||||
|
|||||||
@@ -215,6 +215,13 @@ declare_error_trait!(Error: Sized + Debug + Display);
|
|||||||
/// [`linked-hash-map`]: https://crates.io/crates/linked-hash-map
|
/// [`linked-hash-map`]: https://crates.io/crates/linked-hash-map
|
||||||
/// [`serde_derive`]: https://crates.io/crates/serde_derive
|
/// [`serde_derive`]: https://crates.io/crates/serde_derive
|
||||||
/// [derive section of the manual]: https://serde.rs/derive.html
|
/// [derive section of the manual]: https://serde.rs/derive.html
|
||||||
|
#[cfg_attr(
|
||||||
|
not(no_diagnostic_namespace),
|
||||||
|
diagnostic::on_unimplemented(
|
||||||
|
note = "for local types consider adding `#[derive(serde::Serialize)]` to your `{Self}` type",
|
||||||
|
note = "for types from other crates check whether the crate offers a `serde` feature flag",
|
||||||
|
)
|
||||||
|
)]
|
||||||
pub trait Serialize {
|
pub trait Serialize {
|
||||||
/// Serialize this value into the given Serde serializer.
|
/// Serialize this value into the given Serde serializer.
|
||||||
///
|
///
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "serde_derive"
|
name = "serde_derive"
|
||||||
version = "1.0.203"
|
version = "1.0.205"
|
||||||
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
|
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
|
||||||
categories = ["no-std", "no-std::no-alloc"]
|
categories = ["no-std", "no-std::no-alloc"]
|
||||||
description = "Macros 1.1 implementation of #[derive(Serialize, Deserialize)]"
|
description = "Macros 1.1 implementation of #[derive(Serialize, Deserialize)]"
|
||||||
|
|||||||
@@ -2480,7 +2480,10 @@ fn deserialize_map(
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Collect contents for flatten fields into a buffer
|
// Collect contents for flatten fields into a buffer
|
||||||
let let_collect = if cattrs.has_flatten() {
|
let has_flatten = fields
|
||||||
|
.iter()
|
||||||
|
.any(|field| field.attrs.flatten() && !field.attrs.skip_deserializing());
|
||||||
|
let let_collect = if has_flatten {
|
||||||
Some(quote! {
|
Some(quote! {
|
||||||
let mut __collect = _serde::__private::Vec::<_serde::__private::Option<(
|
let mut __collect = _serde::__private::Vec::<_serde::__private::Option<(
|
||||||
_serde::__private::de::Content,
|
_serde::__private::de::Content,
|
||||||
@@ -2532,7 +2535,7 @@ fn deserialize_map(
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Visit ignored values to consume them
|
// Visit ignored values to consume them
|
||||||
let ignored_arm = if cattrs.has_flatten() {
|
let ignored_arm = if has_flatten {
|
||||||
Some(quote! {
|
Some(quote! {
|
||||||
__Field::__other(__name) => {
|
__Field::__other(__name) => {
|
||||||
__collect.push(_serde::__private::Some((
|
__collect.push(_serde::__private::Some((
|
||||||
@@ -2602,7 +2605,7 @@ fn deserialize_map(
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
let collected_deny_unknown_fields = if cattrs.has_flatten() && cattrs.deny_unknown_fields() {
|
let collected_deny_unknown_fields = if has_flatten && cattrs.deny_unknown_fields() {
|
||||||
Some(quote! {
|
Some(quote! {
|
||||||
if let _serde::__private::Some(_serde::__private::Some((__key, _))) =
|
if let _serde::__private::Some(_serde::__private::Some((__key, _))) =
|
||||||
__collect.into_iter().filter(_serde::__private::Option::is_some).next()
|
__collect.into_iter().filter(_serde::__private::Option::is_some).next()
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
//!
|
//!
|
||||||
//! [https://serde.rs/derive.html]: https://serde.rs/derive.html
|
//! [https://serde.rs/derive.html]: https://serde.rs/derive.html
|
||||||
|
|
||||||
#![doc(html_root_url = "https://docs.rs/serde_derive/1.0.203")]
|
#![doc(html_root_url = "https://docs.rs/serde_derive/1.0.205")]
|
||||||
#![cfg_attr(not(check_cfg), allow(unexpected_cfgs))]
|
#![cfg_attr(not(check_cfg), allow(unexpected_cfgs))]
|
||||||
// Ignored clippy lints
|
// Ignored clippy lints
|
||||||
#![allow(
|
#![allow(
|
||||||
|
|||||||
@@ -18,4 +18,4 @@ rustversion = "1.0"
|
|||||||
serde = { path = "../serde", features = ["rc"] }
|
serde = { path = "../serde", features = ["rc"] }
|
||||||
serde_derive = { path = "../serde_derive", features = ["deserialize_in_place"] }
|
serde_derive = { path = "../serde_derive", features = ["deserialize_in_place"] }
|
||||||
serde_test = "1.0.176"
|
serde_test = "1.0.176"
|
||||||
trybuild = { version = "1.0.66", features = ["diff"] }
|
trybuild = { version = "1.0.97", features = ["diff"] }
|
||||||
|
|||||||
@@ -23,21 +23,21 @@ fn panic(_info: &core::panic::PanicInfo) -> ! {
|
|||||||
use serde_derive::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct Unit;
|
pub struct Unit;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct Newtype(u8);
|
pub struct Newtype(u8);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct Tuple(u8, u8);
|
pub struct Tuple(u8, u8);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct Struct {
|
pub struct Struct {
|
||||||
f: u8,
|
f: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum Enum {
|
pub enum Enum {
|
||||||
Unit,
|
Unit,
|
||||||
Newtype(u8),
|
Newtype(u8),
|
||||||
Tuple(u8, u8),
|
Tuple(u8, u8),
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#[cfg_attr(target_os = "emscripten", ignore)]
|
#[cfg_attr(target_os = "emscripten", ignore = "disabled on Emscripten")]
|
||||||
#[rustversion::attr(not(nightly), ignore)]
|
#[rustversion::attr(not(nightly), ignore = "requires nightly")]
|
||||||
#[cfg_attr(miri, ignore)]
|
#[cfg_attr(miri, ignore = "incompatible with miri")]
|
||||||
#[allow(unused_attributes)]
|
#[allow(unused_attributes)]
|
||||||
#[test]
|
#[test]
|
||||||
fn ui() {
|
fn ui() {
|
||||||
|
|||||||
@@ -162,7 +162,7 @@ fn test_cow() {
|
|||||||
#[test]
|
#[test]
|
||||||
fn test_lifetimes() {
|
fn test_lifetimes() {
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct Cows<'a, 'b> {
|
pub struct Cows<'a, 'b> {
|
||||||
_copied: Cow<'a, str>,
|
_copied: Cow<'a, str>,
|
||||||
|
|
||||||
#[serde(borrow)]
|
#[serde(borrow)]
|
||||||
@@ -178,7 +178,7 @@ fn test_lifetimes() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct Wrap<'a, 'b> {
|
pub struct Wrap<'a, 'b> {
|
||||||
#[serde(borrow = "'b")]
|
#[serde(borrow = "'b")]
|
||||||
_cows: Cows<'a, 'b>,
|
_cows: Cows<'a, 'b>,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ struct StructSkipDefault {
|
|||||||
|
|
||||||
#[derive(PartialEq, Debug, Deserialize)]
|
#[derive(PartialEq, Debug, Deserialize)]
|
||||||
#[serde(default)]
|
#[serde(default)]
|
||||||
struct StructSkipDefaultGeneric<T> {
|
pub struct StructSkipDefaultGeneric<T> {
|
||||||
#[serde(skip_deserializing)]
|
#[serde(skip_deserializing)]
|
||||||
t: T,
|
t: T,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#![deny(warnings)]
|
#![deny(warnings)]
|
||||||
#![allow(
|
#![allow(
|
||||||
|
confusable_idents,
|
||||||
unknown_lints,
|
unknown_lints,
|
||||||
mixed_script_confusables,
|
mixed_script_confusables,
|
||||||
clippy::derive_partial_eq_without_eq,
|
clippy::derive_partial_eq_without_eq,
|
||||||
@@ -19,6 +20,7 @@
|
|||||||
clippy::trivially_copy_pass_by_ref,
|
clippy::trivially_copy_pass_by_ref,
|
||||||
clippy::type_repetition_in_bounds
|
clippy::type_repetition_in_bounds
|
||||||
)]
|
)]
|
||||||
|
#![deny(clippy::collection_is_never_read)]
|
||||||
|
|
||||||
use serde::de::{Deserialize, DeserializeOwned, Deserializer};
|
use serde::de::{Deserialize, DeserializeOwned, Deserializer};
|
||||||
use serde::ser::{Serialize, Serializer};
|
use serde::ser::{Serialize, Serializer};
|
||||||
@@ -287,60 +289,60 @@ fn test_gen() {
|
|||||||
assert::<EmptyEnumVariant>();
|
assert::<EmptyEnumVariant>();
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct NonAsciiIdents {
|
pub struct NonAsciiIdents {
|
||||||
σ: f64,
|
σ: f64,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct EmptyBraced {}
|
pub struct EmptyBraced {}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct EmptyBracedDenyUnknown {}
|
pub struct EmptyBracedDenyUnknown {}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct BracedSkipAll {
|
pub struct BracedSkipAll {
|
||||||
#[serde(skip_deserializing)]
|
#[serde(skip_deserializing)]
|
||||||
f: u8,
|
f: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct BracedSkipAllDenyUnknown {
|
pub struct BracedSkipAllDenyUnknown {
|
||||||
#[serde(skip_deserializing)]
|
#[serde(skip_deserializing)]
|
||||||
f: u8,
|
f: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct EmptyTuple();
|
pub struct EmptyTuple();
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct EmptyTupleDenyUnknown();
|
pub struct EmptyTupleDenyUnknown();
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct TupleSkipAll(#[serde(skip_deserializing)] u8);
|
pub struct TupleSkipAll(#[serde(skip_deserializing)] u8);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct TupleSkipAllDenyUnknown(#[serde(skip_deserializing)] u8);
|
pub struct TupleSkipAllDenyUnknown(#[serde(skip_deserializing)] u8);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum EmptyEnum {}
|
pub enum EmptyEnum {}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
enum EmptyEnumDenyUnknown {}
|
pub enum EmptyEnumDenyUnknown {}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum EnumSkipAll {
|
pub enum EnumSkipAll {
|
||||||
#[serde(skip_deserializing)]
|
#[serde(skip_deserializing)]
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
Variant,
|
Variant,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum EmptyVariants {
|
pub enum EmptyVariants {
|
||||||
Braced {},
|
Braced {},
|
||||||
Tuple(),
|
Tuple(),
|
||||||
BracedSkip {
|
BracedSkip {
|
||||||
@@ -352,7 +354,7 @@ fn test_gen() {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
enum EmptyVariantsDenyUnknown {
|
pub enum EmptyVariantsDenyUnknown {
|
||||||
Braced {},
|
Braced {},
|
||||||
Tuple(),
|
Tuple(),
|
||||||
BracedSkip {
|
BracedSkip {
|
||||||
@@ -364,21 +366,21 @@ fn test_gen() {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct UnitDenyUnknown;
|
pub struct UnitDenyUnknown;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct EmptyArray {
|
pub struct EmptyArray {
|
||||||
empty: [X; 0],
|
empty: [X; 0],
|
||||||
}
|
}
|
||||||
|
|
||||||
enum Or<A, B> {
|
pub enum Or<A, B> {
|
||||||
A(A),
|
A(A),
|
||||||
B(B),
|
B(B),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(untagged, remote = "Or")]
|
#[serde(untagged, remote = "Or")]
|
||||||
enum OrDef<A, B> {
|
pub enum OrDef<A, B> {
|
||||||
A(A),
|
A(A),
|
||||||
B(B),
|
B(B),
|
||||||
}
|
}
|
||||||
@@ -390,7 +392,7 @@ fn test_gen() {
|
|||||||
struct StrDef<'a>(&'a str);
|
struct StrDef<'a>(&'a str);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct Remote<'a> {
|
pub struct Remote<'a> {
|
||||||
#[serde(with = "OrDef")]
|
#[serde(with = "OrDef")]
|
||||||
or: Or<u8, bool>,
|
or: Or<u8, bool>,
|
||||||
#[serde(borrow, with = "StrDef")]
|
#[serde(borrow, with = "StrDef")]
|
||||||
@@ -398,7 +400,7 @@ fn test_gen() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum BorrowVariant<'a> {
|
pub enum BorrowVariant<'a> {
|
||||||
#[serde(borrow, with = "StrDef")]
|
#[serde(borrow, with = "StrDef")]
|
||||||
S(Str<'a>),
|
S(Str<'a>),
|
||||||
}
|
}
|
||||||
@@ -415,14 +417,14 @@ fn test_gen() {
|
|||||||
|
|
||||||
// This would not work if SDef::serialize / deserialize are private.
|
// This would not work if SDef::serialize / deserialize are private.
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct RemoteVisibility {
|
pub struct RemoteVisibility {
|
||||||
#[serde(with = "vis::SDef")]
|
#[serde(with = "vis::SDef")]
|
||||||
s: vis::S,
|
s: vis::S,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "Self")]
|
#[serde(remote = "Self")]
|
||||||
struct RemoteSelf;
|
pub struct RemoteSelf;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum ExternallyTaggedVariantWith {
|
enum ExternallyTaggedVariantWith {
|
||||||
@@ -547,25 +549,25 @@ fn test_gen() {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
struct FlattenDenyUnknown<T> {
|
pub struct FlattenDenyUnknown<T> {
|
||||||
#[serde(flatten)]
|
#[serde(flatten)]
|
||||||
t: T,
|
t: T,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct StaticStrStruct<'a> {
|
pub struct StaticStrStruct<'a> {
|
||||||
a: &'a str,
|
a: &'a str,
|
||||||
b: &'static str,
|
b: &'static str,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct StaticStrTupleStruct<'a>(&'a str, &'static str);
|
pub struct StaticStrTupleStruct<'a>(&'a str, &'static str);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct StaticStrNewtypeStruct(&'static str);
|
pub struct StaticStrNewtypeStruct(&'static str);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum StaticStrEnum<'a> {
|
pub enum StaticStrEnum<'a> {
|
||||||
Struct { a: &'a str, b: &'static str },
|
Struct { a: &'a str, b: &'static str },
|
||||||
Tuple(&'a str, &'static str),
|
Tuple(&'a str, &'static str),
|
||||||
Newtype(&'static str),
|
Newtype(&'static str),
|
||||||
@@ -639,6 +641,7 @@ fn test_gen() {
|
|||||||
use serde_derive::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct Restricted {
|
struct Restricted {
|
||||||
pub(super) a: usize,
|
pub(super) a: usize,
|
||||||
pub(in super::inner) b: usize,
|
pub(in super::inner) b: usize,
|
||||||
@@ -648,7 +651,7 @@ fn test_gen() {
|
|||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
#[serde(tag = "t", content = "c")]
|
#[serde(tag = "t", content = "c")]
|
||||||
enum AdjacentlyTaggedVoid {}
|
pub enum AdjacentlyTaggedVoid {}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum SkippedVariant<T> {
|
enum SkippedVariant<T> {
|
||||||
@@ -661,14 +664,13 @@ fn test_gen() {
|
|||||||
assert::<SkippedVariant<X>>();
|
assert::<SkippedVariant<X>>();
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct ImplicitlyBorrowedOption<'a> {
|
pub struct ImplicitlyBorrowedOption<'a> {
|
||||||
#[allow(dead_code)]
|
|
||||||
option: std::option::Option<&'a str>,
|
option: std::option::Option<&'a str>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(untagged)]
|
#[serde(untagged)]
|
||||||
enum UntaggedNewtypeVariantWith {
|
pub enum UntaggedNewtypeVariantWith {
|
||||||
Newtype(
|
Newtype(
|
||||||
#[serde(serialize_with = "ser_x")]
|
#[serde(serialize_with = "ser_x")]
|
||||||
#[serde(deserialize_with = "de_x")]
|
#[serde(deserialize_with = "de_x")]
|
||||||
@@ -678,7 +680,7 @@ fn test_gen() {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(transparent)]
|
#[serde(transparent)]
|
||||||
struct TransparentWith {
|
pub struct TransparentWith {
|
||||||
#[serde(serialize_with = "ser_x")]
|
#[serde(serialize_with = "ser_x")]
|
||||||
#[serde(deserialize_with = "de_x")]
|
#[serde(deserialize_with = "de_x")]
|
||||||
x: X,
|
x: X,
|
||||||
@@ -700,35 +702,46 @@ fn test_gen() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct RelObject<'a> {
|
pub struct RelObject<'a> {
|
||||||
#[allow(dead_code)]
|
|
||||||
ty: &'a str,
|
ty: &'a str,
|
||||||
#[allow(dead_code)]
|
|
||||||
id: String,
|
id: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct FlattenSkipSerializing<T> {
|
pub struct FlattenSkipSerializing<T> {
|
||||||
#[serde(flatten, skip_serializing)]
|
#[serde(flatten, skip_serializing)]
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
flat: T,
|
flat: T,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct FlattenSkipSerializingIf<T> {
|
pub struct FlattenSkipSerializingIf<T> {
|
||||||
#[serde(flatten, skip_serializing_if = "StdOption::is_none")]
|
#[serde(flatten, skip_serializing_if = "StdOption::is_none")]
|
||||||
flat: StdOption<T>,
|
flat: StdOption<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
struct FlattenSkipDeserializing<T> {
|
pub struct FlattenSkipDeserializing<T> {
|
||||||
#[serde(flatten, skip_deserializing)]
|
#[serde(flatten, skip_deserializing)]
|
||||||
flat: T,
|
flat: T,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Serialize, Deserialize)]
|
||||||
|
#[serde(untagged)]
|
||||||
|
pub enum Inner<T> {
|
||||||
|
Builder {
|
||||||
|
s: T,
|
||||||
|
#[serde(flatten)]
|
||||||
|
o: T,
|
||||||
|
},
|
||||||
|
Default {
|
||||||
|
s: T,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
// https://github.com/serde-rs/serde/issues/1804
|
// https://github.com/serde-rs/serde/issues/1804
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
enum Message {
|
pub enum Message {
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
String(String),
|
String(String),
|
||||||
@@ -747,8 +760,7 @@ fn test_gen() {
|
|||||||
macro_rules! deriving {
|
macro_rules! deriving {
|
||||||
($field:ty) => {
|
($field:ty) => {
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct MacroRules<'a> {
|
pub struct MacroRules<'a> {
|
||||||
#[allow(dead_code)]
|
|
||||||
field: $field,
|
field: $field,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -763,22 +775,20 @@ fn test_gen() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct BorrowLifetimeInsideMacro<'a> {
|
pub struct BorrowLifetimeInsideMacro<'a> {
|
||||||
#[serde(borrow = "'a")]
|
#[serde(borrow = "'a")]
|
||||||
#[allow(dead_code)]
|
pub f: mac!(Cow<'a, str>),
|
||||||
f: mac!(Cow<'a, str>),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize)]
|
#[derive(Serialize)]
|
||||||
#[allow(dead_code)]
|
pub struct Struct {
|
||||||
struct Struct {
|
|
||||||
#[serde(serialize_with = "vec_first_element")]
|
#[serde(serialize_with = "vec_first_element")]
|
||||||
vec: Vec<Self>,
|
pub vec: Vec<Self>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
#[serde(bound(deserialize = "[&'de str; N]: Copy"))]
|
#[serde(bound(deserialize = "[&'de str; N]: Copy"))]
|
||||||
struct GenericUnitStruct<const N: usize>;
|
pub struct GenericUnitStruct<const N: usize>;
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
@@ -865,7 +875,7 @@ where
|
|||||||
|
|
||||||
#[derive(Debug, PartialEq, Deserialize)]
|
#[derive(Debug, PartialEq, Deserialize)]
|
||||||
#[serde(tag = "tag")]
|
#[serde(tag = "tag")]
|
||||||
enum InternallyTagged {
|
pub enum InternallyTagged {
|
||||||
#[serde(deserialize_with = "deserialize_generic")]
|
#[serde(deserialize_with = "deserialize_generic")]
|
||||||
Unit,
|
Unit,
|
||||||
|
|
||||||
|
|||||||
@@ -7,14 +7,17 @@ mod remote {
|
|||||||
|
|
||||||
pub struct PrimitivePriv(u8);
|
pub struct PrimitivePriv(u8);
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub struct PrimitivePub(pub u8);
|
pub struct PrimitivePub(pub u8);
|
||||||
|
|
||||||
pub struct NewtypePriv(Unit);
|
pub struct NewtypePriv(Unit);
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub struct NewtypePub(pub Unit);
|
pub struct NewtypePub(pub Unit);
|
||||||
|
|
||||||
pub struct TuplePriv(u8, Unit);
|
pub struct TuplePriv(u8, Unit);
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub struct TuplePub(pub u8, pub Unit);
|
pub struct TuplePub(pub u8, pub Unit);
|
||||||
|
|
||||||
pub struct StructPriv {
|
pub struct StructPriv {
|
||||||
@@ -22,6 +25,7 @@ mod remote {
|
|||||||
b: Unit,
|
b: Unit,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub struct StructPub {
|
pub struct StructPub {
|
||||||
pub a: u8,
|
pub a: u8,
|
||||||
pub b: Unit,
|
pub b: Unit,
|
||||||
@@ -86,12 +90,14 @@ mod remote {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub enum EnumGeneric<T> {
|
pub enum EnumGeneric<T> {
|
||||||
Variant(T),
|
Variant(T),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct Test {
|
struct Test {
|
||||||
#[serde(with = "UnitDef")]
|
#[serde(with = "UnitDef")]
|
||||||
unit: remote::Unit,
|
unit: remote::Unit,
|
||||||
@@ -132,6 +138,7 @@ struct Test {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::Unit")]
|
#[serde(remote = "remote::Unit")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct UnitDef;
|
struct UnitDef;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
@@ -140,6 +147,7 @@ struct PrimitivePrivDef(#[serde(getter = "remote::PrimitivePriv::get")] u8);
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::PrimitivePub")]
|
#[serde(remote = "remote::PrimitivePub")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct PrimitivePubDef(u8);
|
struct PrimitivePubDef(u8);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
@@ -148,6 +156,7 @@ struct NewtypePrivDef(#[serde(getter = "remote::NewtypePriv::get", with = "UnitD
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::NewtypePub")]
|
#[serde(remote = "remote::NewtypePub")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct NewtypePubDef(#[serde(with = "UnitDef")] remote::Unit);
|
struct NewtypePubDef(#[serde(with = "UnitDef")] remote::Unit);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
@@ -159,6 +168,7 @@ struct TuplePrivDef(
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::TuplePub")]
|
#[serde(remote = "remote::TuplePub")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct TuplePubDef(u8, #[serde(with = "UnitDef")] remote::Unit);
|
struct TuplePubDef(u8, #[serde(with = "UnitDef")] remote::Unit);
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
@@ -174,6 +184,7 @@ struct StructPrivDef {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::StructPub")]
|
#[serde(remote = "remote::StructPub")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct StructPubDef {
|
struct StructPubDef {
|
||||||
a: u8,
|
a: u8,
|
||||||
|
|
||||||
@@ -190,17 +201,20 @@ struct StructGenericWithGetterDef<T> {
|
|||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::StructGeneric<u8>")]
|
#[serde(remote = "remote::StructGeneric<u8>")]
|
||||||
|
#[allow(dead_code)]
|
||||||
struct StructConcrete {
|
struct StructConcrete {
|
||||||
value: u8,
|
value: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "remote::EnumGeneric<u8>")]
|
#[serde(remote = "remote::EnumGeneric<u8>")]
|
||||||
|
#[allow(dead_code)]
|
||||||
enum EnumConcrete {
|
enum EnumConcrete {
|
||||||
Variant(u8),
|
Variant(u8),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
|
#[allow(dead_code)]
|
||||||
enum ErrorKind {
|
enum ErrorKind {
|
||||||
NotFound,
|
NotFound,
|
||||||
PermissionDenied,
|
PermissionDenied,
|
||||||
@@ -211,6 +225,7 @@ enum ErrorKind {
|
|||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
#[serde(remote = "ErrorKind")]
|
#[serde(remote = "ErrorKind")]
|
||||||
#[non_exhaustive]
|
#[non_exhaustive]
|
||||||
|
#[allow(dead_code)]
|
||||||
enum ErrorKindDef {
|
enum ErrorKindDef {
|
||||||
NotFound,
|
NotFound,
|
||||||
PermissionDenied,
|
PermissionDenied,
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ fn test_self() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize)]
|
#[derive(Deserialize, Serialize)]
|
||||||
struct Tuple(
|
pub struct Tuple(
|
||||||
Box<Self>,
|
Box<Self>,
|
||||||
Box<<Self as Trait>::Assoc>,
|
Box<<Self as Trait>::Assoc>,
|
||||||
[(); Self::ASSOC],
|
[(); Self::ASSOC],
|
||||||
@@ -60,7 +60,7 @@ fn test_self() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize)]
|
#[derive(Deserialize, Serialize)]
|
||||||
enum Enum {
|
pub enum Enum {
|
||||||
Struct {
|
Struct {
|
||||||
_f1: Box<Self>,
|
_f1: Box<Self>,
|
||||||
_f2: Box<<Self as Trait>::Assoc>,
|
_f2: Box<<Self as Trait>::Assoc>,
|
||||||
|
|||||||
@@ -0,0 +1,23 @@
|
|||||||
|
use serde::de::Deserialize;
|
||||||
|
use serde::ser::Serialize;
|
||||||
|
|
||||||
|
fn to_string<T>(_: &T) -> String
|
||||||
|
where
|
||||||
|
T: Serialize,
|
||||||
|
{
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn from_str<'de, T>(_: &'de str) -> T
|
||||||
|
where
|
||||||
|
T: Deserialize<'de>,
|
||||||
|
{
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
|
||||||
|
struct MyStruct;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
to_string(&MyStruct);
|
||||||
|
let _: MyStruct = from_str("");
|
||||||
|
}
|
||||||
@@ -0,0 +1,55 @@
|
|||||||
|
error[E0277]: the trait bound `MyStruct: Serialize` is not satisfied
|
||||||
|
--> tests/ui/on_unimplemented.rs:21:15
|
||||||
|
|
|
||||||
|
21 | to_string(&MyStruct);
|
||||||
|
| --------- ^^^^^^^^^ the trait `Serialize` is not implemented for `MyStruct`
|
||||||
|
| |
|
||||||
|
| required by a bound introduced by this call
|
||||||
|
|
|
||||||
|
= note: for local types consider adding `#[derive(serde::Serialize)]` to your `MyStruct` type
|
||||||
|
= note: for types from other crates check whether the crate offers a `serde` feature flag
|
||||||
|
= help: the following other types implement trait `Serialize`:
|
||||||
|
&'a T
|
||||||
|
&'a mut T
|
||||||
|
()
|
||||||
|
(T,)
|
||||||
|
(T0, T1)
|
||||||
|
(T0, T1, T2)
|
||||||
|
(T0, T1, T2, T3)
|
||||||
|
(T0, T1, T2, T3, T4)
|
||||||
|
and $N others
|
||||||
|
note: required by a bound in `to_string`
|
||||||
|
--> tests/ui/on_unimplemented.rs:6:8
|
||||||
|
|
|
||||||
|
4 | fn to_string<T>(_: &T) -> String
|
||||||
|
| --------- required by a bound in this function
|
||||||
|
5 | where
|
||||||
|
6 | T: Serialize,
|
||||||
|
| ^^^^^^^^^ required by this bound in `to_string`
|
||||||
|
|
||||||
|
error[E0277]: the trait bound `MyStruct: Deserialize<'_>` is not satisfied
|
||||||
|
--> tests/ui/on_unimplemented.rs:22:23
|
||||||
|
|
|
||||||
|
22 | let _: MyStruct = from_str("");
|
||||||
|
| ^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `MyStruct`
|
||||||
|
|
|
||||||
|
= note: for local types consider adding `#[derive(serde::Deserialize)]` to your `MyStruct` type
|
||||||
|
= note: for types from other crates check whether the crate offers a `serde` feature flag
|
||||||
|
= help: the following other types implement trait `Deserialize<'de>`:
|
||||||
|
&'a Path
|
||||||
|
&'a [u8]
|
||||||
|
&'a str
|
||||||
|
()
|
||||||
|
(T,)
|
||||||
|
(T0, T1)
|
||||||
|
(T0, T1, T2)
|
||||||
|
(T0, T1, T2, T3)
|
||||||
|
and $N others
|
||||||
|
note: required by a bound in `from_str`
|
||||||
|
--> tests/ui/on_unimplemented.rs:13:8
|
||||||
|
|
|
||||||
|
11 | fn from_str<'de, T>(_: &'de str) -> T
|
||||||
|
| -------- required by a bound in this function
|
||||||
|
12 | where
|
||||||
|
13 | T: Deserialize<'de>,
|
||||||
|
| ^^^^^^^^^^^^^^^^ required by this bound in `from_str`
|
||||||
Reference in New Issue
Block a user