diff --git a/.github/workflows/UnitTest.yml b/.github/workflows/UnitTest.yml index 30275ad3..94429c37 100644 --- a/.github/workflows/UnitTest.yml +++ b/.github/workflows/UnitTest.yml @@ -26,7 +26,7 @@ jobs: # https://github.com/actions/toolkit/issues/399 fail-fast: false matrix: - julia-version: ['1.0', '1', 'nightly'] + julia-version: ['1.0', '1.6', '1', 'nightly'] os: [ubuntu-latest, windows-latest, macOS-latest] julia-arch: [x64] # only test one 32-bit job diff --git a/Project.toml b/Project.toml index 89386a84..cc3ebcbe 100644 --- a/Project.toml +++ b/Project.toml @@ -1,6 +1,6 @@ name = "OffsetArrays" uuid = "6fe1bfb0-de20-5000-8ca7-80f57d26f881" -version = "1.12.0" +version = "1.12.1" [deps] Adapt = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" diff --git a/src/axes.jl b/src/axes.jl index 0422141f..1b530d88 100644 --- a/src/axes.jl +++ b/src/axes.jl @@ -246,12 +246,31 @@ for R in [:IIUR, :IdOffsetRange] end # offset-preserve broadcasting -Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(-), r::IdOffsetRange{T}, x::Integer) where T = - IdOffsetRange{T}(r.parent .- x, r.offset) -Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(+), r::IdOffsetRange{T}, x::Integer) where T = - IdOffsetRange{T}(r.parent .+ x, r.offset) -Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(+), x::Integer, r::IdOffsetRange{T}) where T = - IdOffsetRange{T}(x .+ r.parent, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(-), r::IdOffsetRange) = + OffsetArray(.-UnitRange(r), r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(-), r::IdOffsetRange, x::Integer) = + IdOffsetRange(r.parent .- x, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(-), x::Integer, r::IdOffsetRange) = + OffsetArray(x .- UnitRange(r), r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(+), r::IdOffsetRange, x::Integer) = + IdOffsetRange(r.parent .+ x, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(+), x::Integer, r::IdOffsetRange) = + IdOffsetRange(x .+ r.parent, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(*), x::Number, r::IdOffsetRange) = + OffsetArray(x .* UnitRange(r), r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(*), r::IdOffsetRange, x::Number) = + OffsetArray(UnitRange(r) .* x, r.offset) +# specialize for AbstractFloat to resolve ambiguity with OrdinalRange +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(*), x::AbstractFloat, r::IdOffsetRange) = + OffsetArray(x .* UnitRange(r), r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(*), r::IdOffsetRange, x::AbstractFloat) = + OffsetArray(UnitRange(r) .* x, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(\), x::Number, r::IdOffsetRange) = + OffsetArray(x .\ UnitRange(r), r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(/), r::IdOffsetRange, x::Number) = + OffsetArray(UnitRange(r) ./ x, r.offset) +Broadcast.broadcasted(::Base.Broadcast.DefaultArrayStyle{1}, ::typeof(big), r::IdOffsetRange) = + IdOffsetRange(big.(r.parent), r.offset) Base.show(io::IO, r::IdOffsetRange) = print(io, IdOffsetRange, "(values=",first(r), ':', last(r),", indices=",first(eachindex(r)),':',last(eachindex(r)), ")") diff --git a/test/runtests.jl b/test/runtests.jl index 078a95d3..217a96bf 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -158,8 +158,29 @@ end # broadcasting behavior with scalars (issue #104) r3 = (1 .+ OffsetArrays.IdOffsetRange(3:5, -1) .+ 1) .- 1 + @test r3 isa OffsetArrays.IdOffsetRange @test same_value(r3, 3:5) - check_indexed_by(r3, 0:2) + check_indexed_by(r3, axes(r3,1)) + + r = OffsetArrays.IdOffsetRange(3:5, -1) + rc = copyto!(similar(r), r) + n = big(typemax(Int)) + @test @inferred(broadcast(+, r, n)) == @inferred(broadcast(+, n, r)) == rc .+ n + @test @inferred(broadcast(-, r)) == .-rc + @test @inferred(broadcast(big, r)) == big.(rc) + for n in Any[2, big(typemax(Int))] + @test @inferred(broadcast(+, r, n)) == @inferred(broadcast(+, n, r)) == rc .+ n + @test @inferred(broadcast(-, r, n)) == rc .- n + @test @inferred(broadcast(-, n, r)) == n .- rc + @test @inferred(broadcast(*, r, n)) == @inferred(broadcast(*, n, r)) == rc .* n + if VERSION >= v"1.6.0" + # this test fails on v1.0 due to a bug in evaluating (3:5) / big(2) + @test @inferred(broadcast(/, r, n)) == @inferred(broadcast(\, n, r)) == rc ./ n + end + end + for n in (VERSION >= v"1.6.0" ? Any[2.0, big(2.0)] : Any[2.0]) + @test @inferred(broadcast(*, r, n)) == @inferred(broadcast(*, n, r)) == rc .* n + end @testset "Idempotent indexing" begin @testset "Indexing into an IdOffsetRange" begin