From 214a1b006c7be2cd432636ba65230d6a4184a7c4 Mon Sep 17 00:00:00 2001 From: Reuben Gardos Reid <5456207+ReubenJ@users.noreply.github.com> Date: Fri, 5 Jul 2024 15:31:33 +0200 Subject: [PATCH 1/3] Resolve ambiguous method def for `Base.in(...)` For `StateStack`, one of the arguments was previously non parameterized --- src/solver/uniform_solver/state_stack.jl | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/solver/uniform_solver/state_stack.jl b/src/solver/uniform_solver/state_stack.jl index df6be52..d54343c 100644 --- a/src/solver/uniform_solver/state_stack.jl +++ b/src/solver/uniform_solver/state_stack.jl @@ -64,6 +64,6 @@ end Checks whether the `value` is in the `stack`. """ -function Base.in(stack::StateStack, value)::Bool +function Base.in(stack::StateStack{T}, value::T)::Bool where T return value ∈ stack.vec[1:size(stack)] end From bca7e7427a6b1ae3e45c5d6bf32f571d164910e9 Mon Sep 17 00:00:00 2001 From: Reuben Gardos Reid <5456207+ReubenJ@users.noreply.github.com> Date: Fri, 5 Jul 2024 15:32:06 +0200 Subject: [PATCH 2/3] Bump minor version number --- Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Project.toml b/Project.toml index 3188359..e7de4dc 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "HerbConstraints" uuid = "1fa96474-3206-4513-b4fa-23913f296dfc" authors = ["Jaap de Jong "] -version = "0.2.1" +version = "0.2.2" [deps] DataStructures = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" From b207190873b4988bc0aec4ca01a410d899526f18 Mon Sep 17 00:00:00 2001 From: Reuben Gardos Reid <5456207+ReubenJ@users.noreply.github.com> Date: Fri, 5 Jul 2024 15:45:18 +0200 Subject: [PATCH 3/3] Add tests for `in` for `StateStack`s --- test/test_state_stack.jl | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/test/test_state_stack.jl b/test/test_state_stack.jl index 66523ef..3ec86e4 100644 --- a/test/test_state_stack.jl +++ b/test/test_state_stack.jl @@ -9,6 +9,28 @@ @test size(stack) == 0 end + @testset "membership" begin + sm = HerbConstraints.StateManager() + stack = HerbConstraints.StateStack{Int}(sm) + push!(stack, 10) + push!(stack, 20) + push!(stack, 30) + @test in(stack, 10) + @test in(stack, 20) + @test in(stack, 30) + @test !in(stack, 40) + + sm = HerbConstraints.StateManager() + stack = HerbConstraints.StateStack{String}(sm) + push!(stack, "A") + push!(stack, "B") + push!(stack, "C") + @test in(stack, "A") + @test in(stack, "B") + @test in(stack, "C") + @test !in(stack, "D") + end + @testset "from vector" begin sm = HerbConstraints.StateManager() stack = HerbConstraints.StateStack{Int}(sm, [10, 20, 30])