From 0a0ea9299a10a51b196148001868fdcbe1e5caea Mon Sep 17 00:00:00 2001 From: Julien Jerphanion Date: Mon, 24 Jun 2024 10:34:27 +0200 Subject: [PATCH] fix: Add a virtual destructor to `DependencyProvider` (#50) * fix: Add a virtual destructor to `DependencyProvider` Signed-off-by: Julien Jerphanion * lint: Format file Signed-off-by: Julien Jerphanion --------- Signed-off-by: Julien Jerphanion --- cpp/include/resolvo_dependency_provider.h | 2 ++ cpp/tests/solve.cpp | 5 +++++ 2 files changed, 7 insertions(+) diff --git a/cpp/include/resolvo_dependency_provider.h b/cpp/include/resolvo_dependency_provider.h index 5f56c9c..8cd9258 100644 --- a/cpp/include/resolvo_dependency_provider.h +++ b/cpp/include/resolvo_dependency_provider.h @@ -18,6 +18,8 @@ using cbindgen_private::VersionSetId; * An interface that implements ecosystem specific logic. */ struct DependencyProvider { + virtual ~DependencyProvider() = default; + /** * Returns a user-friendly string representation of the specified solvable. * diff --git a/cpp/tests/solve.cpp b/cpp/tests/solve.cpp index 92dad7f..ffb8c66 100644 --- a/cpp/tests/solve.cpp +++ b/cpp/tests/solve.cpp @@ -167,6 +167,11 @@ SCENARIO("Solve") { /// Construct a database with packages a, b, and c. PackageDatabase db; + // Check that PackageDatabase correctly implements the DependencyProvider interface + static_assert(std::has_virtual_destructor_v); + static_assert(std::is_polymorphic_v); + static_assert(std::is_base_of_v); + auto a_1 = db.alloc_candidate("a", 1, {{db.alloc_requirement("b", 1, 4)}, {}}); auto a_2 = db.alloc_candidate("a", 2, {{db.alloc_requirement("b", 1, 4)}, {}}); auto a_3 = db.alloc_candidate("a", 3, {{db.alloc_requirement("b", 4, 7)}, {}});