Compare commits

...

21 Commits

Author SHA1 Message Date
David Tolnay ab1ca04b2e Release 1.0.131 2021-12-08 18:47:15 -08:00
David Tolnay fb2fe409c8 Touch up PR 2116 2021-12-08 18:44:41 -08:00
David Tolnay 549fac7235 Merge pull request #2116 from tyranron/fix-unused-results
Fix `unused_results` complaining rustc lint in codegen for adjacently tagged enum
2021-12-08 18:43:31 -08:00
David Tolnay c375d8b19b Merge pull request #2124 from dtolnay/cbor
Change cbor link to new repo
2021-11-26 14:48:40 -08:00
David Tolnay 6cf507f808 Change cbor link to new repo 2021-11-26 14:43:09 -08:00
David Tolnay c3c1641c06 Remove workaround for redundant_field_names Clippy bug 2021-11-04 20:23:25 -07:00
David Tolnay 1fcda0ebdb Enable pedantic lints on test suite in CI 2021-11-04 20:21:48 -07:00
David Tolnay 8f16ac0a94 Move deny(clippy) to command line arguments in the CI job 2021-11-04 20:09:35 -07:00
David Tolnay 737f78c315 Ignore enum_variant_names Clippy lint in test suite
error: all variants have the same prefix: `Serialize`
        --> test_suite/tests/test_macros.rs:1741:5
         |
    1741 | /     enum E {
    1742 | |         #[serde(rename_all = "camelCase")]
    1743 | |         Serialize {
    1744 | |             serialize: bool,
    ...    |
    1756 | |         },
    1757 | |     }
         | |_____^
         |
         = note: `-D clippy::enum-variant-names` implied by `-D clippy::all`
         = help: remove the prefixes and use full paths to the variants instead of glob imports
         = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#enum_variant_names
2021-11-04 20:06:02 -07:00
David Tolnay 4a97386cb9 Clippy if_then_panic lint has been renamed to manual_assert 2021-11-04 19:57:14 -07:00
tyranron 5b32217877 Fix unused_results complaining rustc lint in codegen for adjacently tagged enum 2021-10-29 14:13:26 +03:00
David Tolnay 5b140361a3 Merge pull request #2102 from atouchet/url
Update URL
2021-10-14 16:33:22 -07:00
Alex Touchet 678351eac7 Update URL 2021-10-14 16:27:49 -07:00
David Tolnay 999c261d11 Ui test changes for trybuild 1.0.49 2021-10-08 02:46:15 -04:00
David Tolnay efbe574209 Update ui test files 2021-10-07 00:56:29 -04:00
David Tolnay 33b2677384 Suppress broken semicolon_if_nothing_returned lint
https://github.com/rust-lang/rust-clippy/issues/7768

    error: consider adding a `;` to the last statement for consistent formatting
       --> serde/src/de/impls.rs:849:1
        |
    849 | / seq_impl!(
    850 | |     BinaryHeap<T: Ord>,
    851 | |     seq,
    852 | |     BinaryHeap::clear,
    ...   |
    855 | |     BinaryHeap::push
    856 | | );
        | |__^
        |
    note: the lint level is defined here
       --> serde/src/lib.rs:97:52
        |
    97  | #![cfg_attr(feature = "cargo-clippy", deny(clippy, clippy_pedantic))]
        |                                                    ^^^^^^^^^^^^^^^
        = note: `#[deny(clippy::semicolon_if_nothing_returned)]` implied by `#[deny(clippy::pedantic)]`
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
        |
    849 + seq_impl!(
    850 +     BinaryHeap<T: Ord>,
    851 +     seq,
    852 +     BinaryHeap::clear,
    853 +     BinaryHeap::with_capacity(size_hint::cautious(seq.size_hint())),
    854 +     BinaryHeap::reserve,
      ...

    error: consider adding a `;` to the last statement for consistent formatting
       --> serde/src/de/impls.rs:859:1
        |
    859 | / seq_impl!(
    860 | |     BTreeSet<T: Eq + Ord>,
    861 | |     seq,
    862 | |     BTreeSet::clear,
    ...   |
    865 | |     BTreeSet::insert
    866 | | );
        | |__^
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
        |
    859 + seq_impl!(
    860 +     BTreeSet<T: Eq + Ord>,
    861 +     seq,
    862 +     BTreeSet::clear,
    863 +     BTreeSet::new(),
    864 +     nop_reserve,
      ...

    error: consider adding a `;` to the last statement for consistent formatting
       --> serde/src/de/impls.rs:869:1
        |
    869 | / seq_impl!(
    870 | |     LinkedList<T>,
    871 | |     seq,
    872 | |     LinkedList::clear,
    ...   |
    875 | |     LinkedList::push_back
    876 | | );
        | |__^
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
        |
    869 + seq_impl!(
    870 +     LinkedList<T>,
    871 +     seq,
    872 +     LinkedList::clear,
    873 +     LinkedList::new(),
    874 +     nop_reserve,
      ...

    error: consider adding a `;` to the last statement for consistent formatting
       --> serde/src/de/impls.rs:879:1
        |
    879 | / seq_impl!(
    880 | |     HashSet<T: Eq + Hash, S: BuildHasher + Default>,
    881 | |     seq,
    882 | |     HashSet::clear,
    883 | |     HashSet::with_capacity_and_hasher(size_hint::cautious(seq.size_hint()), S::default()),
    884 | |     HashSet::reserve,
    885 | |     HashSet::insert);
        | |_____________________^
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
        |
    879 + seq_impl!(
    880 +     HashSet<T: Eq + Hash, S: BuildHasher + Default>,
    881 +     seq,
    882 +     HashSet::clear,
    883 +     HashSet::with_capacity_and_hasher(size_hint::cautious(seq.size_hint()), S::default()),
    884 +     HashSet::reserve,
      ...

    error: consider adding a `;` to the last statement for consistent formatting
       --> serde/src/de/impls.rs:888:1
        |
    888 | / seq_impl!(
    889 | |     VecDeque<T>,
    890 | |     seq,
    891 | |     VecDeque::clear,
    ...   |
    894 | |     VecDeque::push_back
    895 | | );
        | |__^
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
        |
    888 + seq_impl!(
    889 +     VecDeque<T>,
    890 +     seq,
    891 +     VecDeque::clear,
    892 +     VecDeque::with_capacity(size_hint::cautious(seq.size_hint())),
    893 +     VecDeque::reserve,
      ...

    error: consider adding a `;` to the last statement for consistent formatting
        --> serde/src/de/impls.rs:1300:1
         |
    1300 | / map_impl!(
    1301 | |     BTreeMap<K: Ord, V>,
    1302 | |     map,
    1303 | |     BTreeMap::new());
         | |_____________________^
         |
         = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
         |
    1300 + map_impl!(
    1301 +     BTreeMap<K: Ord, V>,
    1302 +     map,
    1303 +     BTreeMap::new());;
         |

    error: consider adding a `;` to the last statement for consistent formatting
        --> serde/src/de/impls.rs:1306:1
         |
    1306 | / map_impl!(
    1307 | |     HashMap<K: Eq + Hash, V, S: BuildHasher + Default>,
    1308 | |     map,
    1309 | |     HashMap::with_capacity_and_hasher(size_hint::cautious(map.size_hint()), S::default()));
         | |___________________________________________________________________________________________^
         |
         = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#semicolon_if_nothing_returned
    help: add a `;` here
         |
    1306 + map_impl!(
    1307 +     HashMap<K: Eq + Hash, V, S: BuildHasher + Default>,
    1308 +     map,
    1309 +     HashMap::with_capacity_and_hasher(size_hint::cautious(map.size_hint()), S::default()));;
         |
2021-10-04 23:57:05 -04:00
David Tolnay 01ded9f405 Declare minimum Rust version in Cargo metadata 2021-10-02 02:43:22 -04:00
David Tolnay fc827ecec2 Resolve redundant_closure_for_method_calls clippy lints
error: redundant closure
      --> serde_derive/src/bound.rs:53:19
       |
    53 |         .flat_map(|predicates| predicates.to_vec());
       |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the method itself: `[T]::to_vec`
       |
    note: the lint level is defined here
      --> serde_derive/src/lib.rs:18:22
       |
    18 | #![deny(clippy::all, clippy::pedantic)]
       |                      ^^^^^^^^^^^^^^^^
       = note: `#[deny(clippy::redundant_closure_for_method_calls)]` implied by `#[deny(clippy::pedantic)]`
       = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure_for_method_calls

    error: redundant closure
      --> serde_derive/src/bound.rs:75:19
       |
    75 |         .flat_map(|predicates| predicates.to_vec());
       |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the method itself: `[T]::to_vec`
       |
       = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure_for_method_calls
2021-09-30 00:31:49 -04:00
David Tolnay 5c785eee58 Ignore if_then_panic clippy lint
error: only a `panic!` in `if`-then statement
      --> serde_derive/src/internals/ctxt.rs:58:9
       |
    58 | /         if !thread::panicking() && self.errors.borrow().is_some() {
    59 | |             panic!("forgot to check for errors");
    60 | |         }
       | |_________^ help: try: `assert!(!!thread::panicking() && self.errors.borrow().is_some(), "forgot to check for errors");`
       |
    note: the lint level is defined here
      --> serde_derive/src/lib.rs:18:9
       |
    18 | #![deny(clippy::all, clippy::pedantic)]
       |         ^^^^^^^^^^^
       = note: `#[deny(clippy::if_then_panic)]` implied by `#[deny(clippy::all)]`
       = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
       --> serde_test/src/assert.rs:73:5
        |
    73  | /     if ser.remaining() > 0 {
    74  | |         panic!("{} remaining tokens", ser.remaining());
    75  | |     }
        | |_____^ help: try: `assert!(!ser.remaining() > 0, "{} remaining tokens", ser.remaining());`
        |
    note: the lint level is defined here
       --> serde_test/src/lib.rs:149:44
        |
    149 | #![cfg_attr(feature = "cargo-clippy", deny(clippy, clippy_pedantic))]
        |                                            ^^^^^^
        = note: `#[deny(clippy::if_then_panic)]` implied by `#[deny(clippy::all)]`
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
       --> serde_test/src/assert.rs:126:5
        |
    126 | /     if ser.remaining() > 0 {
    127 | |         panic!("{} remaining tokens", ser.remaining());
    128 | |     }
        | |_____^ help: try: `assert!(!ser.remaining() > 0, "{} remaining tokens", ser.remaining());`
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
       --> serde_test/src/assert.rs:166:5
        |
    166 | /     if de.remaining() > 0 {
    167 | |         panic!("{} remaining tokens", de.remaining());
    168 | |     }
        | |_____^ help: try: `assert!(!de.remaining() > 0, "{} remaining tokens", de.remaining());`
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
       --> serde_test/src/assert.rs:180:5
        |
    180 | /     if de.remaining() > 0 {
    181 | |         panic!("{} remaining tokens", de.remaining());
    182 | |     }
        | |_____^ help: try: `assert!(!de.remaining() > 0, "{} remaining tokens", de.remaining());`
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
       --> serde_test/src/assert.rs:220:5
        |
    220 | /     if de.remaining() > 0 {
    221 | |         panic!("{} remaining tokens", de.remaining());
    222 | |     }
        | |_____^ help: try: `assert!(!de.remaining() > 0, "{} remaining tokens", de.remaining());`
        |
        = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic

    error: only a `panic!` in `if`-then statement
        --> test_suite/tests/test_de.rs:1349:9
         |
    1349 | /         if de.remaining() > 0 {
    1350 | |             panic!("{} remaining tokens", de.remaining());
    1351 | |         }
         | |_________^ help: try: `assert!(!de.remaining() > 0, "{} remaining tokens", de.remaining());`
         |
         = note: `-D clippy::if-then-panic` implied by `-D clippy::all`
         = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_then_panic
2021-09-30 00:31:49 -04:00
David Tolnay 819db93a3d Format with rustfmt 2021-09-29 2021-09-30 00:31:49 -04:00
David Tolnay a6690ea2fe Update ui test suite to nightly-2021-09-14 2021-09-14 19:13:54 -07:00
117 changed files with 169 additions and 139 deletions
+6 -8
View File
@@ -153,11 +153,9 @@ jobs:
steps:
- uses: actions/checkout@v2
- uses: dtolnay/rust-toolchain@clippy
# The need for -Aredundant_field_names here is a Clippy bug.
# https://github.com/rust-lang/rust-clippy/issues/5356
- run: cd serde && cargo clippy --features rc,unstable -- -D clippy::all -A clippy::redundant_field_names
- run: cd serde_derive && cargo clippy -- -D clippy::all
- run: cd serde_derive_internals && cargo clippy -- -D clippy::all
- run: cd serde_test && cargo clippy -- -D clippy::all -A clippy::redundant_field_names
- run: cd test_suite && cargo clippy --tests --features unstable -- -D clippy::all -A clippy::redundant_field_names
- run: cd test_suite/no_std && cargo clippy -- -D clippy::all -A clippy::redundant_field_names
- run: cd serde && cargo clippy --features rc,unstable -- -Dclippy::all -Dclippy::pedantic
- run: cd serde_derive && cargo clippy -- -Dclippy::all -Dclippy::pedantic
- run: cd serde_derive_internals && cargo clippy -- -Dclippy::all -Dclippy::pedantic
- run: cd serde_test && cargo clippy -- -Dclippy::all -Dclippy::pedantic
- run: cd test_suite && cargo clippy --tests --features unstable -- -Dclippy::all -Dclippy::pedantic
- run: cd test_suite/no_std && cargo clippy -- -Dclippy::all -Dclippy::pedantic
+3 -2
View File
@@ -1,7 +1,8 @@
[package]
name = "serde"
version = "1.0.130" # remember to update html_root_url and serde_derive dependency
version = "1.0.131" # remember to update html_root_url and serde_derive dependency
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
rust-version = "1.15"
license = "MIT OR Apache-2.0"
description = "A generic serialization/deserialization framework"
homepage = "https://serde.rs"
@@ -14,7 +15,7 @@ include = ["build.rs", "src/**/*.rs", "crates-io.md", "README.md", "LICENSE-APAC
build = "build.rs"
[dependencies]
serde_derive = { version = "=1.0.130", optional = true, path = "../serde_derive" }
serde_derive = { version = "=1.0.131", optional = true, path = "../serde_derive" }
[dev-dependencies]
serde_derive = { version = "1.0", path = "../serde_derive" }
+5 -4
View File
@@ -60,7 +60,7 @@
//!
//! [JSON]: https://github.com/serde-rs/json
//! [Bincode]: https://github.com/servo/bincode
//! [CBOR]: https://github.com/pyfisch/cbor
//! [CBOR]: https://github.com/enarx/ciborium
//! [YAML]: https://github.com/dtolnay/serde-yaml
//! [MessagePack]: https://github.com/3Hren/msgpack-rust
//! [TOML]: https://github.com/alexcrichton/toml-rs
@@ -73,7 +73,7 @@
//! [URL]: https://docs.rs/serde_qs
//! [Envy]: https://github.com/softprops/envy
//! [Envy Store]: https://github.com/softprops/envy-store
//! [Cargo]: http://doc.crates.io/manifest.html
//! [Cargo]: https://doc.rust-lang.org/cargo/reference/manifest.html
//! [AWS Parameter Store]: https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-paramstore.html
//! [S-expressions]: https://github.com/rotty/lexpr-rs
//! [D-Bus]: https://docs.rs/zvariant
@@ -84,7 +84,7 @@
////////////////////////////////////////////////////////////////////////////////
// Serde types in rustdoc of other crates get linked to here.
#![doc(html_root_url = "https://docs.rs/serde/1.0.130")]
#![doc(html_root_url = "https://docs.rs/serde/1.0.131")]
// Support using Serde without the standard library!
#![cfg_attr(not(feature = "std"), no_std)]
// Unstable functionality only if the user asks for it. For tracking and
@@ -94,13 +94,14 @@
#![cfg_attr(feature = "unstable", feature(never_type))]
#![allow(unknown_lints, bare_trait_objects, deprecated)]
#![cfg_attr(feature = "cargo-clippy", allow(renamed_and_removed_lints))]
#![cfg_attr(feature = "cargo-clippy", deny(clippy, clippy_pedantic))]
// Ignored clippy and clippy_pedantic lints
#![cfg_attr(
feature = "cargo-clippy",
allow(
// clippy bug: https://github.com/rust-lang/rust-clippy/issues/5704
unnested_or_patterns,
// clippy bug: https://github.com/rust-lang/rust-clippy/issues/7768
semicolon_if_nothing_returned,
// not available in our oldest supported compiler
checked_conversions,
empty_enum,
+2 -1
View File
@@ -1,7 +1,8 @@
[package]
name = "serde_derive"
version = "1.0.130" # remember to update html_root_url
version = "1.0.131" # remember to update html_root_url
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
rust-version = "1.31"
license = "MIT OR Apache-2.0"
description = "Macros 1.1 implementation of #[derive(Serialize, Deserialize)]"
homepage = "https://serde.rs"
+2 -2
View File
@@ -50,7 +50,7 @@ pub fn with_where_predicates_from_fields(
.data
.all_fields()
.filter_map(|field| from_field(&field.attrs))
.flat_map(|predicates| predicates.to_vec());
.flat_map(<[syn::WherePredicate]>::to_vec);
let mut generics = generics.clone();
generics.make_where_clause().predicates.extend(predicates);
@@ -72,7 +72,7 @@ pub fn with_where_predicates_from_variants(
let predicates = variants
.iter()
.filter_map(|variant| from_variant(&variant.attrs))
.flat_map(|predicates| predicates.to_vec());
.flat_map(<[syn::WherePredicate]>::to_vec);
let mut generics = generics.clone();
generics.make_where_clause().predicates.extend(predicates);
+1 -1
View File
@@ -1458,7 +1458,7 @@ fn deserialize_adjacently_tagged_enum(
while let _serde::__private::Some(__k) = #next_key {
match __k {
_serde::__private::de::TagContentOtherField::Other => {
try!(_serde::de::MapAccess::next_value::<_serde::de::IgnoredAny>(&mut __map));
let _ = try!(_serde::de::MapAccess::next_value::<_serde::de::IgnoredAny>(&mut __map));
continue;
},
_serde::__private::de::TagContentOtherField::Tag => {
+2 -2
View File
@@ -13,9 +13,8 @@
//!
//! [https://serde.rs/derive.html]: https://serde.rs/derive.html
#![doc(html_root_url = "https://docs.rs/serde_derive/1.0.130")]
#![doc(html_root_url = "https://docs.rs/serde_derive/1.0.131")]
#![allow(unknown_lints, bare_trait_objects)]
#![deny(clippy::all, clippy::pedantic)]
// Ignored clippy lints
#![allow(
// clippy false positive: https://github.com/rust-lang/rust-clippy/issues/7054
@@ -44,6 +43,7 @@
clippy::indexing_slicing,
clippy::items_after_statements,
clippy::let_underscore_drop,
clippy::manual_assert,
clippy::map_err_ignore,
clippy::match_same_arms,
// clippy bug: https://github.com/rust-lang/rust-clippy/issues/6984
+7 -5
View File
@@ -65,11 +65,13 @@ pub fn pretend_used(cont: &Container, is_packed: bool) -> TokenStream {
fn pretend_fields_used(cont: &Container, is_packed: bool) -> TokenStream {
match &cont.data {
Data::Enum(variants) => pretend_fields_used_enum(cont, variants),
Data::Struct(Style::Struct, fields) => if is_packed {
pretend_fields_used_struct_packed(cont, fields)
} else {
pretend_fields_used_struct(cont, fields)
},
Data::Struct(Style::Struct, fields) => {
if is_packed {
pretend_fields_used_struct_packed(cont, fields)
} else {
pretend_fields_used_struct(cont, fields)
}
}
Data::Struct(_, _) => quote!(),
}
}
+1
View File
@@ -2,6 +2,7 @@
name = "serde_derive_internals"
version = "0.26.0" # remember to update html_root_url
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
rust-version = "1.31"
license = "MIT OR Apache-2.0"
description = "AST representation used by Serde derive macros. Unstable."
homepage = "https://serde.rs"
+1 -1
View File
@@ -1,6 +1,5 @@
#![doc(html_root_url = "https://docs.rs/serde_derive_internals/0.26.0")]
#![allow(unknown_lints, bare_trait_objects)]
#![deny(clippy::all, clippy::pedantic)]
// Ignored clippy lints
#![allow(
clippy::cognitive_complexity,
@@ -23,6 +22,7 @@
clippy::enum_glob_use,
clippy::items_after_statements,
clippy::let_underscore_drop,
clippy::manual_assert,
clippy::match_same_arms,
// clippy bug: https://github.com/rust-lang/rust-clippy/issues/6984
clippy::match_wildcard_for_single_variants,
+2 -1
View File
@@ -1,7 +1,8 @@
[package]
name = "serde_test"
version = "1.0.130" # remember to update html_root_url
version = "1.0.131" # remember to update html_root_url
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>", "David Tolnay <dtolnay@gmail.com>"]
rust-version = "1.15"
license = "MIT OR Apache-2.0"
description = "Token De/Serializer for testing De/Serialize implementations"
homepage = "https://serde.rs"
+2 -2
View File
@@ -144,9 +144,8 @@
//! # }
//! ```
#![doc(html_root_url = "https://docs.rs/serde_test/1.0.130")]
#![doc(html_root_url = "https://docs.rs/serde_test/1.0.131")]
#![cfg_attr(feature = "cargo-clippy", allow(renamed_and_removed_lints))]
#![cfg_attr(feature = "cargo-clippy", deny(clippy, clippy_pedantic))]
// Ignored clippy lints
#![cfg_attr(feature = "cargo-clippy", allow(float_cmp, needless_doctest_main))]
// Ignored clippy_pedantic lints
@@ -155,6 +154,7 @@
allow(
cloned_instead_of_copied,
empty_line_after_outer_attr,
manual_assert,
missing_docs_in_private_items,
missing_panics_doc,
module_name_repetitions,
+1 -1
View File
@@ -23,4 +23,4 @@ rustversion = "1.0"
serde = { path = "../serde", features = ["rc", "derive"] }
serde_derive = { path = "../serde_derive", features = ["deserialize_in_place"] }
serde_test = { path = "../serde_test" }
trybuild = { version = "1.0.19", features = ["diff"] }
trybuild = { version = "1.0.49", features = ["diff"] }
+1
View File
@@ -3,6 +3,7 @@
clippy::from_over_into,
// Clippy bug: https://github.com/rust-lang/rust-clippy/issues/7422
clippy::nonstandard_macro_braces,
clippy::too_many_lines,
clippy::trivially_copy_pass_by_ref
)]
+2
View File
@@ -1,3 +1,5 @@
#![allow(clippy::items_after_statements, clippy::used_underscore_binding)]
use serde::{Deserialize, Deserializer};
use serde_test::{assert_de_tokens, assert_de_tokens_error, Token};
+7 -1
View File
@@ -1,4 +1,10 @@
#![allow(clippy::decimal_literal_representation, clippy::unreadable_literal)]
#![allow(
clippy::decimal_literal_representation,
clippy::empty_enum,
clippy::manual_assert,
clippy::needless_pass_by_value,
clippy::unreadable_literal
)]
#![cfg_attr(feature = "unstable", feature(never_type))]
use std::collections::{BTreeMap, BTreeSet, HashMap, HashSet};
+5
View File
@@ -6,9 +6,14 @@
#![allow(
unknown_lints,
mixed_script_confusables,
clippy::items_after_statements,
clippy::missing_errors_doc,
clippy::missing_panics_doc,
clippy::must_use_candidate,
// Clippy bug: https://github.com/rust-lang/rust-clippy/issues/7422
clippy::nonstandard_macro_braces,
clippy::ptr_arg,
clippy::too_many_lines,
clippy::trivially_copy_pass_by_ref
)]
+5 -1
View File
@@ -1,5 +1,9 @@
#![deny(trivial_numeric_casts)]
#![allow(clippy::redundant_field_names)]
#![allow(
clippy::enum_variant_names,
clippy::redundant_field_names,
clippy::too_many_lines
)]
mod bytes;
+2
View File
@@ -1,3 +1,5 @@
#![allow(clippy::used_underscore_binding)]
use serde::{Deserialize, Serialize};
#[test]
+2
View File
@@ -1,3 +1,5 @@
#![allow(clippy::type_repetition_in_bounds)]
#[test]
fn test_gen_custom_serde() {
#[derive(serde::Serialize, serde::Deserialize)]
+2
View File
@@ -1,3 +1,5 @@
#![allow(clippy::similar_names)]
use serde::de::value::{self, MapAccessDeserializer};
use serde::de::{IntoDeserializer, MapAccess, Visitor};
use serde::{Deserialize, Deserializer};
@@ -1,5 +1,5 @@
error: failed to parse borrowed lifetimes: "zzz"
--> $DIR/bad_lifetimes.rs:5:22
--> tests/ui/borrow/bad_lifetimes.rs:5:22
|
5 | #[serde(borrow = "zzz")]
| ^^^^^
@@ -1,5 +1,5 @@
error: duplicate borrowed lifetime `'a`
--> $DIR/duplicate_lifetime.rs:5:22
--> tests/ui/borrow/duplicate_lifetime.rs:5:22
|
5 | #[serde(borrow = "'a + 'a")]
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `borrow`
--> $DIR/duplicate_variant.rs:8:13
--> tests/ui/borrow/duplicate_variant.rs:8:13
|
8 | #[serde(borrow)]
| ^^^^^^
@@ -1,5 +1,5 @@
error: at least one lifetime must be borrowed
--> $DIR/empty_lifetimes.rs:5:22
--> tests/ui/borrow/empty_lifetimes.rs:5:22
|
5 | #[serde(borrow = "")]
| ^^
@@ -1,5 +1,5 @@
error: field `s` has no lifetimes to borrow
--> $DIR/no_lifetimes.rs:5:5
--> tests/ui/borrow/no_lifetimes.rs:5:5
|
5 | / #[serde(borrow)]
6 | | s: String,
@@ -1,5 +1,5 @@
error: #[serde(borrow)] may only be used on newtype variants
--> $DIR/struct_variant.rs:8:5
--> tests/ui/borrow/struct_variant.rs:8:5
|
8 | / #[serde(borrow)]
9 | | S { s: Str<'a> },
@@ -1,5 +1,5 @@
error: field `s` does not have lifetime 'b
--> $DIR/wrong_lifetime.rs:5:5
--> tests/ui/borrow/wrong_lifetime.rs:5:5
|
5 | / #[serde(borrow = "'b")]
6 | | s: &'a str,
@@ -1,5 +1,5 @@
error: enum tags `conflict` for type and content conflict with each other
--> $DIR/adjacent-tag.rs:4:1
--> tests/ui/conflict/adjacent-tag.rs:4:1
|
4 | / #[serde(tag = "conflict", content = "conflict")]
5 | | enum E {
@@ -1,5 +1,5 @@
error: #[serde(flatten)] cannot be used on newtype structs
--> $DIR/flatten-newtype-struct.rs:6:12
--> tests/ui/conflict/flatten-newtype-struct.rs:6:12
|
6 | struct Foo(#[serde(flatten)] HashMap<String, String>);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(flatten)] cannot be used on tuple structs
--> $DIR/flatten-tuple-struct.rs:6:17
--> tests/ui/conflict/flatten-tuple-struct.rs:6:17
|
6 | struct Foo(u32, #[serde(flatten)] HashMap<String, String>);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(from = "...")] and #[serde(try_from = "...")] conflict with each other
--> $DIR/from-try-from.rs:4:1
--> tests/ui/conflict/from-try-from.rs:4:1
|
4 | / #[serde(from = "u64", try_from = "u64")]
5 | | struct S {
@@ -1,5 +1,5 @@
error: variant field name `conflict` conflicts with internal tag
--> $DIR/internal-tag-alias.rs:4:1
--> tests/ui/conflict/internal-tag-alias.rs:4:1
|
4 | / #[serde(tag = "conflict")]
5 | | enum E {
@@ -1,5 +1,5 @@
error: variant field name `conflict` conflicts with internal tag
--> $DIR/internal-tag.rs:4:1
--> tests/ui/conflict/internal-tag.rs:4:1
|
4 | / #[serde(tag = "conflict")]
5 | | enum E {
@@ -1,5 +1,5 @@
error: #[serde(default)] can only be used on structs with named fields
--> $DIR/enum.rs:5:1
--> tests/ui/default-attribute/enum.rs:5:1
|
5 | enum E {
| ^^^^
@@ -1,5 +1,5 @@
error: #[serde(default = "...")] can only be used on structs with named fields
--> $DIR/enum_path.rs:5:1
--> tests/ui/default-attribute/enum_path.rs:5:1
|
5 | enum E {
| ^^^^
@@ -1,5 +1,5 @@
error: #[serde(default)] can only be used on structs with named fields
--> $DIR/nameless_struct_fields.rs:5:9
--> tests/ui/default-attribute/nameless_struct_fields.rs:5:9
|
5 | struct T(u8, u8);
| ^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(default = "...")] can only be used on structs with named fields
--> $DIR/nameless_struct_fields_path.rs:5:9
--> tests/ui/default-attribute/nameless_struct_fields_path.rs:5:9
|
5 | struct T(u8, u8);
| ^^^^^^^^
@@ -1,5 +1,5 @@
error: unknown serde field attribute `serialize`
--> $DIR/rename-and-ser.rs:5:27
--> tests/ui/duplicate-attribute/rename-and-ser.rs:5:27
|
5 | #[serde(rename = "x", serialize = "y")]
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `rename`
--> $DIR/rename-ser-rename-ser.rs:5:38
--> tests/ui/duplicate-attribute/rename-ser-rename-ser.rs:5:38
|
5 | #[serde(rename(serialize = "x"), rename(serialize = "y"))]
| ^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `rename`
--> $DIR/rename-ser-rename.rs:6:13
--> tests/ui/duplicate-attribute/rename-ser-rename.rs:6:13
|
6 | #[serde(rename = "y")]
| ^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `rename`
--> $DIR/rename-ser-ser.rs:5:37
--> tests/ui/duplicate-attribute/rename-ser-ser.rs:5:37
|
5 | #[serde(rename(serialize = "x", serialize = "y"))]
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `rename`
--> $DIR/two-rename-ser.rs:6:13
--> tests/ui/duplicate-attribute/two-rename-ser.rs:6:13
|
6 | #[serde(rename(serialize = "y"))]
| ^^^^^^
@@ -1,5 +1,5 @@
error: duplicate serde attribute `serialize_with`
--> $DIR/with-and-serialize-with.rs:5:25
--> tests/ui/duplicate-attribute/with-and-serialize-with.rs:5:25
|
5 | #[serde(with = "w", serialize_with = "s")]
| ^^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(tag = "...", content = "...")] must be used together
--> $DIR/content-no-tag.rs:4:9
--> tests/ui/enum-representation/content-no-tag.rs:4:9
|
4 | #[serde(content = "c")]
| ^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(tag = "...")] cannot be used with tuple variants
--> $DIR/internal-tuple-variant.rs:6:5
--> tests/ui/enum-representation/internal-tuple-variant.rs:6:5
|
6 | Tuple(u8, u8),
| ^^^^^^^^^^^^^
@@ -1,17 +1,17 @@
error: untagged enum cannot have #[serde(tag = "...", content = "...")]
--> $DIR/untagged-and-adjacent.rs:4:9
--> tests/ui/enum-representation/untagged-and-adjacent.rs:4:9
|
4 | #[serde(untagged)]
| ^^^^^^^^
error: untagged enum cannot have #[serde(tag = "...", content = "...")]
--> $DIR/untagged-and-adjacent.rs:5:9
--> tests/ui/enum-representation/untagged-and-adjacent.rs:5:9
|
5 | #[serde(tag = "t", content = "c")]
| ^^^
error: untagged enum cannot have #[serde(tag = "...", content = "...")]
--> $DIR/untagged-and-adjacent.rs:5:20
--> tests/ui/enum-representation/untagged-and-adjacent.rs:5:20
|
5 | #[serde(tag = "t", content = "c")]
| ^^^^^^^
@@ -1,11 +1,11 @@
error: untagged enum cannot have #[serde(content = "...")]
--> $DIR/untagged-and-content.rs:4:9
--> tests/ui/enum-representation/untagged-and-content.rs:4:9
|
4 | #[serde(untagged)]
| ^^^^^^^^
error: untagged enum cannot have #[serde(content = "...")]
--> $DIR/untagged-and-content.rs:5:9
--> tests/ui/enum-representation/untagged-and-content.rs:5:9
|
5 | #[serde(content = "c")]
| ^^^^^^^
@@ -1,11 +1,11 @@
error: enum cannot be both untagged and internally tagged
--> $DIR/untagged-and-internal.rs:4:9
--> tests/ui/enum-representation/untagged-and-internal.rs:4:9
|
4 | #[serde(untagged)]
| ^^^^^^^^
error: enum cannot be both untagged and internally tagged
--> $DIR/untagged-and-internal.rs:5:9
--> tests/ui/enum-representation/untagged-and-internal.rs:5:9
|
5 | #[serde(tag = "type")]
| ^^^
@@ -1,5 +1,5 @@
error: #[serde(untagged)] can only be used on enums
--> $DIR/untagged-struct.rs:5:1
--> tests/ui/enum-representation/untagged-struct.rs:5:1
|
5 | struct S;
| ^^^^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/boolean.rs:5:22
--> tests/ui/expected-string/boolean.rs:5:22
|
5 | #[serde(rename = true)]
| ^^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/byte_character.rs:5:22
--> tests/ui/expected-string/byte_character.rs:5:22
|
5 | #[serde(rename = b'a')]
| ^^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/byte_string.rs:5:22
--> tests/ui/expected-string/byte_string.rs:5:22
|
5 | #[serde(rename = b"byte string")]
| ^^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/character.rs:5:22
--> tests/ui/expected-string/character.rs:5:22
|
5 | #[serde(rename = 'a')]
| ^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/float.rs:5:22
--> tests/ui/expected-string/float.rs:5:22
|
5 | #[serde(rename = 3.14)]
| ^^^^
@@ -1,5 +1,5 @@
error: expected serde rename attribute to be a string: `rename = "..."`
--> $DIR/integer.rs:5:22
--> tests/ui/expected-string/integer.rs:5:22
|
5 | #[serde(rename = 100)]
| ^^^
+2 -2
View File
@@ -1,11 +1,11 @@
error: #[serde(field_identifier)] and #[serde(variant_identifier)] cannot both be set
--> $DIR/both.rs:4:9
--> tests/ui/identifier/both.rs:4:9
|
4 | #[serde(field_identifier, variant_identifier)]
| ^^^^^^^^^^^^^^^^
error: #[serde(field_identifier)] and #[serde(variant_identifier)] cannot both be set
--> $DIR/both.rs:4:27
--> tests/ui/identifier/both.rs:4:27
|
4 | #[serde(field_identifier, variant_identifier)]
| ^^^^^^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(field_identifier)] can only be used on an enum
--> $DIR/field_struct.rs:5:1
--> tests/ui/identifier/field_struct.rs:5:1
|
5 | struct S;
| ^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(field_identifier)] may only contain unit variants
--> $DIR/field_tuple.rs:7:5
--> tests/ui/identifier/field_tuple.rs:7:5
|
7 | B(u8, u8),
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: `Other` must be the last variant
--> $DIR/newtype_not_last.rs:7:5
--> tests/ui/identifier/newtype_not_last.rs:7:5
|
7 | Other(String),
| ^^^^^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(other)] must be on a unit variant
--> $DIR/not_unit.rs:7:5
--> tests/ui/identifier/not_unit.rs:7:5
|
7 | / #[serde(other)]
8 | | Other(u8, u8),
@@ -1,5 +1,5 @@
error: #[serde(other)] must be on the last variant
--> $DIR/other_not_last.rs:7:5
--> tests/ui/identifier/other_not_last.rs:7:5
|
7 | / #[serde(other)]
8 | | Other,
@@ -1,5 +1,5 @@
error: #[serde(other)] cannot appear on untagged enum
--> $DIR/other_untagged.rs:6:5
--> tests/ui/identifier/other_untagged.rs:6:5
|
6 | / #[serde(other)]
7 | | Other,
@@ -1,5 +1,5 @@
error: #[serde(other)] may not be used on a variant identifier
--> $DIR/other_variant.rs:6:5
--> tests/ui/identifier/other_variant.rs:6:5
|
6 | / #[serde(other)]
7 | | Other,
@@ -1,5 +1,5 @@
error: #[serde(variant_identifier)] can only be used on an enum
--> $DIR/variant_struct.rs:5:1
--> tests/ui/identifier/variant_struct.rs:5:1
|
5 | struct S;
| ^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(variant_identifier)] may only contain unit variants
--> $DIR/variant_tuple.rs:7:5
--> tests/ui/identifier/variant_tuple.rs:7:5
|
7 | B(u8, u8),
| ^^^^^^^^^
+1 -1
View File
@@ -1,5 +1,5 @@
error: malformed bound attribute, expected `bound(serialize = ..., deserialize = ...)`
--> $DIR/bound.rs:5:19
--> tests/ui/malformed/bound.rs:5:19
|
5 | #[serde(bound(unknown))]
| ^^^^^^^
+1 -1
View File
@@ -1,5 +1,5 @@
error: unexpected end of input, expected literal
--> $DIR/cut_off.rs:4:17
--> tests/ui/malformed/cut_off.rs:4:17
|
4 | #[serde(rename =)]
| ^
@@ -1,11 +1,11 @@
error: expected #[serde(...)]
--> $DIR/not_list.rs:4:3
--> tests/ui/malformed/not_list.rs:4:3
|
4 | #[serde]
| ^^^^^
error: expected #[serde(...)]
--> $DIR/not_list.rs:5:3
--> tests/ui/malformed/not_list.rs:5:3
|
5 | #[serde = "?"]
| ^^^^^^^^^^^
+1 -1
View File
@@ -1,5 +1,5 @@
error: malformed rename attribute, expected `rename(serialize = ..., deserialize = ...)`
--> $DIR/rename.rs:5:20
--> tests/ui/malformed/rename.rs:5:20
|
5 | #[serde(rename(unknown))]
| ^^^^^^^
@@ -1,5 +1,5 @@
error: cannot deserialize when there is a lifetime parameter called 'de
--> $DIR/deserialize_de_lifetime.rs:4:10
--> tests/ui/precondition/deserialize_de_lifetime.rs:4:10
|
4 | struct S<'de> {
| ^^^
@@ -1,5 +1,5 @@
error: cannot deserialize a dynamically sized struct
--> $DIR/deserialize_dst.rs:4:1
--> tests/ui/precondition/deserialize_dst.rs:4:1
|
4 | / struct S {
5 | | string: String,
@@ -1,5 +1,5 @@
error: field identifiers cannot be serialized
--> $DIR/serialize_field_identifier.rs:4:1
--> tests/ui/precondition/serialize_field_identifier.rs:4:1
|
4 | / #[serde(field_identifier)]
5 | | enum F {
@@ -1,5 +1,5 @@
error: variant identifiers cannot be serialized
--> $DIR/serialize_variant_identifier.rs:4:1
--> tests/ui/precondition/serialize_variant_identifier.rs:4:1
|
4 | / #[serde(variant_identifier)]
5 | | enum F {
+1 -1
View File
@@ -1,5 +1,5 @@
error: failed to parse path: "~~~"
--> $DIR/bad_getter.rs:12:22
--> tests/ui/remote/bad_getter.rs:12:22
|
12 | #[serde(getter = "~~~")]
| ^^^^^
+1 -1
View File
@@ -1,5 +1,5 @@
error: failed to parse path: "~~~"
--> $DIR/bad_remote.rs:10:18
--> tests/ui/remote/bad_remote.rs:10:18
|
10 | #[serde(remote = "~~~")]
| ^^^^^
@@ -1,5 +1,5 @@
error: #[serde(getter = "...")] is not allowed in an enum
--> $DIR/enum_getter.rs:10:1
--> tests/ui/remote/enum_getter.rs:10:1
|
10 | / #[serde(remote = "remote::E")]
11 | | pub enum E {
@@ -1,5 +1,5 @@
error[E0063]: missing field `b` in initializer of `remote::S`
--> $DIR/missing_field.rs:11:18
--> tests/ui/remote/missing_field.rs:11:18
|
11 | #[serde(remote = "remote::S")]
| ^^^^^^^^^^^ missing `b`
@@ -1,5 +1,5 @@
error: #[serde(getter = "...")] can only be used in structs that have #[serde(remote = "...")]
--> $DIR/nonremote_getter.rs:4:1
--> tests/ui/remote/nonremote_getter.rs:4:1
|
4 | / struct S {
5 | | #[serde(getter = "S::get")]
@@ -1,11 +1,11 @@
error[E0609]: no field `b` on type `&remote::S`
--> $DIR/unknown_field.rs:12:5
--> tests/ui/remote/unknown_field.rs:12:5
|
12 | b: u8,
| ^ help: a field with a similar name exists: `a`
error[E0560]: struct `remote::S` has no field named `b`
--> $DIR/unknown_field.rs:12:5
--> tests/ui/remote/unknown_field.rs:12:5
|
12 | b: u8,
| ^ help: a field with a similar name exists: `a`
+6 -5
View File
@@ -1,10 +1,11 @@
error[E0308]: mismatched types
--> $DIR/wrong_de.rs:7:10
--> tests/ui/remote/wrong_de.rs:7:10
|
7 | #[derive(Deserialize)]
| ^^^^^^^^^^^
| |
| expected `u16`, found `u8`
| help: you can convert a `u8` to a `u16`: `Deserialize.into()`
| ^^^^^^^^^^^ expected `u16`, found `u8`
|
= note: this error originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
help: you can convert a `u8` to a `u16`
|
7 | #[derive(Deserialize.into())]
| +++++++
@@ -1,5 +1,5 @@
error[E0308]: mismatched types
--> $DIR/wrong_getter.rs:15:10
--> tests/ui/remote/wrong_getter.rs:15:10
|
15 | #[derive(Serialize)]
| ^^^^^^^^^ expected `u8`, found `u16`
+1 -1
View File
@@ -1,5 +1,5 @@
error[E0308]: mismatched types
--> $DIR/wrong_ser.rs:9:10
--> tests/ui/remote/wrong_ser.rs:9:10
|
9 | #[derive(Serialize)]
| ^^^^^^^^^ expected `u8`, found `u16`
@@ -1,5 +1,5 @@
error: unknown rename rule `rename_all = "abc"`, expected one of "lowercase", "UPPERCASE", "PascalCase", "camelCase", "snake_case", "SCREAMING_SNAKE_CASE", "kebab-case", "SCREAMING-KEBAB-CASE"
--> $DIR/container_unknown_rename_rule.rs:4:22
--> tests/ui/rename/container_unknown_rename_rule.rs:4:22
|
4 | #[serde(rename_all = "abc")]
| ^^^^^
@@ -1,5 +1,5 @@
error: unknown rename rule `rename_all = "abc"`, expected one of "lowercase", "UPPERCASE", "PascalCase", "camelCase", "snake_case", "SCREAMING_SNAKE_CASE", "kebab-case", "SCREAMING-KEBAB-CASE"
--> $DIR/variant_unknown_rename_rule.rs:5:26
--> tests/ui/rename/variant_unknown_rename_rule.rs:5:26
|
5 | #[serde(rename_all = "abc")]
| ^^^^^
@@ -1,5 +1,5 @@
error: #[serde(tag = "...")] can only be used on enums and structs with named fields
--> $DIR/internally-tagged-tuple.rs:5:9
--> tests/ui/struct-representation/internally-tagged-tuple.rs:5:9
|
5 | struct S(u8, u8);
| ^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(tag = "...")] can only be used on enums and structs with named fields
--> $DIR/internally-tagged-unit.rs:3:10
--> tests/ui/struct-representation/internally-tagged-unit.rs:3:10
|
3 | #[derive(Serialize)]
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: #[serde(transparent)] requires struct to have at most one transparent field
--> $DIR/at_most_one.rs:4:1
--> tests/ui/transparent/at_most_one.rs:4:1
|
4 | / #[serde(transparent)]
5 | | struct S {
@@ -1,5 +1,5 @@
error: #[serde(transparent)] requires at least one field that is neither skipped nor has a default
--> $DIR/de_at_least_one.rs:4:1
--> tests/ui/transparent/de_at_least_one.rs:4:1
|
4 | / #[serde(transparent)]
5 | | struct S {
+1 -1
View File
@@ -1,5 +1,5 @@
error: #[serde(transparent)] is not allowed on an enum
--> $DIR/enum.rs:4:1
--> tests/ui/transparent/enum.rs:4:1
|
4 | / #[serde(transparent)]
5 | | enum E {}
@@ -1,5 +1,5 @@
error: #[serde(transparent)] requires at least one field that is not skipped
--> $DIR/ser_at_least_one.rs:4:1
--> tests/ui/transparent/ser_at_least_one.rs:4:1
|
4 | / #[serde(transparent)]
5 | | struct S {
@@ -1,5 +1,5 @@
error: #[serde(transparent)] is not allowed on a unit struct
--> $DIR/unit_struct.rs:4:1
--> tests/ui/transparent/unit_struct.rs:4:1
|
4 | / #[serde(transparent)]
5 | | struct S;
@@ -1,5 +1,5 @@
error: #[serde(transparent)] is not allowed with #[serde(from = "...")]
--> $DIR/with_from.rs:4:1
--> tests/ui/transparent/with_from.rs:4:1
|
4 | / #[serde(transparent, from = "u64")]
5 | | struct S {
@@ -1,5 +1,5 @@
error: #[serde(transparent)] is not allowed with #[serde(into = "...")]
--> $DIR/with_into.rs:4:1
--> tests/ui/transparent/with_into.rs:4:1
|
4 | / #[serde(transparent, into = "u64")]
5 | | struct S {
@@ -1,5 +1,5 @@
error: #[serde(transparent)] is not allowed with #[serde(try_from = "...")]
--> $DIR/with_try_from.rs:4:1
--> tests/ui/transparent/with_try_from.rs:4:1
|
4 | / #[serde(transparent, try_from = "u64")]
5 | | struct S {
@@ -1,5 +1,5 @@
error: failed to parse type: from = "Option<T"
--> $DIR/from.rs:4:16
--> tests/ui/type-attribute/from.rs:4:16
|
4 | #[serde(from = "Option<T")]
| ^^^^^^^^^^
@@ -1,5 +1,5 @@
error: failed to parse type: into = "Option<T"
--> $DIR/into.rs:4:16
--> tests/ui/type-attribute/into.rs:4:16
|
4 | #[serde(into = "Option<T")]
| ^^^^^^^^^^
@@ -1,5 +1,5 @@
error: failed to parse type: try_from = "Option<T"
--> $DIR/try_from.rs:4:20
--> tests/ui/type-attribute/try_from.rs:4:20
|
4 | #[serde(try_from = "Option<T")]
| ^^^^^^^^^^
@@ -1,5 +1,5 @@
error: unexpected literal in serde container attribute
--> $DIR/container.rs:4:9
--> tests/ui/unexpected-literal/container.rs:4:9
|
4 | #[serde("literal")]
| ^^^^^^^^^
@@ -1,5 +1,5 @@
error: unexpected literal in serde field attribute
--> $DIR/field.rs:5:13
--> tests/ui/unexpected-literal/field.rs:5:13
|
5 | #[serde("literal")]
| ^^^^^^^^^

Some files were not shown because too many files have changed in this diff Show More