From 69033e6995a27ed3b6f8734981587a8fa7bf05f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Manuel=20Seeb=C3=B6ck?= Date: Wed, 13 Dec 2023 15:57:31 +0100 Subject: [PATCH 1/2] fixed variant varadic default constructed state --- include/etl/private/variant_variadic.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/etl/private/variant_variadic.h b/include/etl/private/variant_variadic.h index 28b2d99a0..399e5e90c 100644 --- a/include/etl/private/variant_variadic.h +++ b/include/etl/private/variant_variadic.h @@ -531,7 +531,7 @@ namespace etl default_construct_in_place(data); operation = operation_type::value, etl::is_move_constructible::value>::do_operation; - type_id = 0U; + type_id = variant_npos; } #include "diagnostic_pop.h" From 9fc7a346e991760a31b93895cc9e22e77dceb545 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Manuel=20Seeb=C3=B6ck?= Date: Mon, 18 Dec 2023 13:04:07 +0100 Subject: [PATCH 2/2] updated testcases to account for default contructor changes --- test/test_variant_variadic.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/test/test_variant_variadic.cpp b/test/test_variant_variadic.cpp index 34e9178c0..e35d48e89 100644 --- a/test/test_variant_variadic.cpp +++ b/test/test_variant_variadic.cpp @@ -420,15 +420,15 @@ namespace test_variant_etl_3 variant_etl; - CHECK(etl::holds_alternative(variant_etl)); + CHECK(!etl::holds_alternative(variant_etl)); CHECK(!etl::holds_alternative(variant_etl)); CHECK(!etl::holds_alternative(variant_etl)); - CHECK(etl::holds_alternative<0U>(variant_etl)); + CHECK(!etl::holds_alternative<0U>(variant_etl)); CHECK(!etl::holds_alternative<1U>(variant_etl)); CHECK(!etl::holds_alternative<2U>(variant_etl)); - CHECK(etl::holds_alternative(0U, variant_etl)); + CHECK(!etl::holds_alternative(0U, variant_etl)); CHECK(!etl::holds_alternative(1U, variant_etl)); CHECK(!etl::holds_alternative(2U, variant_etl)); CHECK(!etl::holds_alternative(99U, variant_etl)); @@ -1830,7 +1830,7 @@ namespace //************************************************************************* TEST(test_variant_visit_void) { - etl::variant variant1; + etl::variant variant1 = int8_t{}; bool variant_was_signed{}; auto const f = [&variant_was_signed](auto v) @@ -1857,7 +1857,7 @@ namespace std::string result = "?"; - etl::variant package; + etl::variant package = TypeA{}; etl::visit(etl::overload {