From 83332971b76656963b551a074ccf2f5a0d0b7f1e Mon Sep 17 00:00:00 2001 From: Gerhard Aigner Date: Wed, 13 Nov 2019 01:47:30 +0100 Subject: [PATCH] Fix findfirst with decreasing step range (#33809) Fixes #33808 --- base/array.jl | 3 ++- test/ranges.jl | 2 ++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/base/array.jl b/base/array.jl index 4200cef10a42a..82dbf6ea08d2b 100644 --- a/base/array.jl +++ b/base/array.jl @@ -1773,7 +1773,8 @@ findfirst(testf::Function, A::Union{AbstractArray, AbstractString}) = findnext(testf, A, first(keys(A))) function findfirst(p::Union{Fix2{typeof(isequal),T},Fix2{typeof(==),T}}, r::StepRange{T,S}) where {T,S} - first(r) <= p.x <= last(r) || return nothing + isempty(r) && return nothing + minimum(r) <= p.x <= maximum(r) || return nothing d = convert(S, p.x - first(r)) iszero(d % step(r)) || return nothing return d รท step(r) + 1 diff --git a/test/ranges.jl b/test/ranges.jl index c765900f6d78b..cbd5ef36b84ce 100644 --- a/test/ranges.jl +++ b/test/ranges.jl @@ -305,6 +305,8 @@ end @test findfirst(==(7), 1:2:10) == 4 @test findfirst(==(10), 1:2:10) == nothing @test findfirst(==(11), 1:2:10) == nothing + @test findfirst(==(-7), 1:-1:-10) == 9 + @test findfirst(==(2),1:-1:2) == nothing end @testset "reverse" begin @test reverse(reverse(1:10)) == 1:10