From d1b2d29528b7794b41e66fc2136e395a02f8529b Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 30 May 2024 05:59:35 +0200 Subject: Merging upstream version 1.73.0+dfsg1. Signed-off-by: Daniel Baumann --- .../tests/compile-fail/default_expr_wrong_type.rs | 12 ++++++++ .../compile-fail/default_expr_wrong_type.stderr | 21 ++++++++++++++ .../tests/compile-fail/not_impl_from_meta.rs | 16 +++++++++++ .../tests/compile-fail/not_impl_from_meta.stderr | 33 ++++++++++++++++++++++ .../compile-fail/skip_field_not_impl_default.rs | 18 ++++++++++++ .../skip_field_not_impl_default.stderr | 21 ++++++++++++++ 6 files changed, 121 insertions(+) create mode 100644 vendor/darling/tests/compile-fail/default_expr_wrong_type.rs create mode 100644 vendor/darling/tests/compile-fail/default_expr_wrong_type.stderr create mode 100644 vendor/darling/tests/compile-fail/not_impl_from_meta.rs create mode 100644 vendor/darling/tests/compile-fail/not_impl_from_meta.stderr create mode 100644 vendor/darling/tests/compile-fail/skip_field_not_impl_default.rs create mode 100644 vendor/darling/tests/compile-fail/skip_field_not_impl_default.stderr (limited to 'vendor/darling/tests/compile-fail') diff --git a/vendor/darling/tests/compile-fail/default_expr_wrong_type.rs b/vendor/darling/tests/compile-fail/default_expr_wrong_type.rs new file mode 100644 index 000000000..cd9a0fd1e --- /dev/null +++ b/vendor/darling/tests/compile-fail/default_expr_wrong_type.rs @@ -0,0 +1,12 @@ +use darling::FromMeta; + +#[derive(FromMeta)] +struct Receiver { + #[darling(default = "usize::default")] + not_u32: String, + + #[darling(multiple, default = "usize::default")] + also_not_u32: Vec, +} + +fn main() {} diff --git a/vendor/darling/tests/compile-fail/default_expr_wrong_type.stderr b/vendor/darling/tests/compile-fail/default_expr_wrong_type.stderr new file mode 100644 index 000000000..a8b7c502b --- /dev/null +++ b/vendor/darling/tests/compile-fail/default_expr_wrong_type.stderr @@ -0,0 +1,21 @@ +error[E0308]: mismatched types + --> tests/compile-fail/default_expr_wrong_type.rs:5:25 + | +5 | #[darling(default = "usize::default")] + | ^^^^^^^^^^^^^^^^ expected struct `String`, found `usize` + | +help: try using a conversion method + | +5 | #[darling(default = "usize::default".to_string())] + | ++++++++++++ +5 | #[darling(default = "usize::default".to_string())] + | ++++++++++++ + +error[E0308]: mismatched types + --> tests/compile-fail/default_expr_wrong_type.rs:8:35 + | +8 | #[darling(multiple, default = "usize::default")] + | ^^^^^^^^^^^^^^^^ expected struct `Vec`, found `usize` + | + = note: expected struct `Vec` + found type `usize` diff --git a/vendor/darling/tests/compile-fail/not_impl_from_meta.rs b/vendor/darling/tests/compile-fail/not_impl_from_meta.rs new file mode 100644 index 000000000..f27d71639 --- /dev/null +++ b/vendor/darling/tests/compile-fail/not_impl_from_meta.rs @@ -0,0 +1,16 @@ +use darling::FromMeta; + +struct NotImplFm; + +#[derive(FromMeta)] +struct OuterFm { + inner: NotImplFm, +} + +#[derive(darling::FromDeriveInput)] +#[darling(attributes(hello))] +struct OuterFdi { + inner: NotImplFm, +} + +fn main() {} diff --git a/vendor/darling/tests/compile-fail/not_impl_from_meta.stderr b/vendor/darling/tests/compile-fail/not_impl_from_meta.stderr new file mode 100644 index 000000000..a166a6fcf --- /dev/null +++ b/vendor/darling/tests/compile-fail/not_impl_from_meta.stderr @@ -0,0 +1,33 @@ +error[E0277]: the trait bound `NotImplFm: FromMeta` is not satisfied + --> tests/compile-fail/not_impl_from_meta.rs:7:12 + | +7 | inner: NotImplFm, + | ^^^^^^^^^ the trait `FromMeta` is not implemented for `NotImplFm` + | + = help: the following other types implement trait `FromMeta`: + () + Arc + AtomicBool + ExprArray + ExprPath + Flag + HashMap + HashMap + and $N others + +error[E0277]: the trait bound `NotImplFm: FromMeta` is not satisfied + --> tests/compile-fail/not_impl_from_meta.rs:13:12 + | +13 | inner: NotImplFm, + | ^^^^^^^^^ the trait `FromMeta` is not implemented for `NotImplFm` + | + = help: the following other types implement trait `FromMeta`: + () + Arc + AtomicBool + ExprArray + ExprPath + Flag + HashMap + HashMap + and $N others diff --git a/vendor/darling/tests/compile-fail/skip_field_not_impl_default.rs b/vendor/darling/tests/compile-fail/skip_field_not_impl_default.rs new file mode 100644 index 000000000..f0d44c779 --- /dev/null +++ b/vendor/darling/tests/compile-fail/skip_field_not_impl_default.rs @@ -0,0 +1,18 @@ +use darling::FromMeta; + +#[derive(FromMeta)] +struct NoDefault(String); + +#[derive(FromMeta)] +struct Recevier { + #[darling(skip)] + skipped: NoDefault, + + #[darling(skip = true)] + explicitly_skipped: NoDefault, + + #[darling(skip = false)] + not_skipped_no_problem: NoDefault, +} + +fn main() {} diff --git a/vendor/darling/tests/compile-fail/skip_field_not_impl_default.stderr b/vendor/darling/tests/compile-fail/skip_field_not_impl_default.stderr new file mode 100644 index 000000000..de46982c2 --- /dev/null +++ b/vendor/darling/tests/compile-fail/skip_field_not_impl_default.stderr @@ -0,0 +1,21 @@ +error[E0277]: the trait bound `NoDefault: std::default::Default` is not satisfied + --> tests/compile-fail/skip_field_not_impl_default.rs:8:15 + | +8 | #[darling(skip)] + | ^^^^ the trait `std::default::Default` is not implemented for `NoDefault` + | +help: consider annotating `NoDefault` with `#[derive(Default)]` + | +4 | #[derive(Default)] + | + +error[E0277]: the trait bound `NoDefault: std::default::Default` is not satisfied + --> tests/compile-fail/skip_field_not_impl_default.rs:11:22 + | +11 | #[darling(skip = true)] + | ^^^^ the trait `std::default::Default` is not implemented for `NoDefault` + | +help: consider annotating `NoDefault` with `#[derive(Default)]` + | +4 | #[derive(Default)] + | -- cgit v1.2.3