Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add default constructors for AbstractRange #48894

Open
wants to merge 32 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
e6784b9
add default constructors for AbstractRange
putianyi889 Mar 4, 2023
25f2021
Update range.jl
putianyi889 Mar 9, 2023
9f89130
whitespace
putianyi889 Mar 9, 2023
bc35354
add tests
putianyi889 Mar 10, 2023
0d588d4
whitespace
putianyi889 Mar 10, 2023
023b619
Merge branch 'JuliaLang:master' into patch-1
putianyi889 Mar 16, 2023
be8943e
add AbstractVector and AbstractArray constructor
putianyi889 Mar 16, 2023
52e7177
add tests
putianyi889 Mar 16, 2023
4e9740d
Update range.jl
putianyi889 Mar 17, 2023
32d838f
fix
putianyi889 Mar 17, 2023
7eb8b63
Update test/ranges.jl
putianyi889 Mar 25, 2024
5224278
Merge branch 'master' into patch-1
jishnub Aug 17, 2024
77a5a54
Update range.jl
putianyi889 Oct 30, 2024
6f16b36
add tests
putianyi889 Oct 30, 2024
7e53aa3
Merge branch 'master' into patch-1
putianyi889 Oct 30, 2024
db47bb9
support `StepRangeLen`, `LinRange`, move codes to promotion section
putianyi889 Oct 30, 2024
d148d2d
add tests
putianyi889 Oct 30, 2024
80c70af
Update ranges.jl
putianyi889 Oct 31, 2024
c13c97c
fix
putianyi889 Oct 31, 2024
3c01806
add tests
putianyi889 Oct 31, 2024
57854ee
Update range.jl
putianyi889 Oct 31, 2024
2e76189
whitespace
putianyi889 Oct 31, 2024
9324d21
Update ranges.jl
putianyi889 Oct 31, 2024
02b3d2f
Update range.jl
putianyi889 Oct 31, 2024
fdabcb5
fix
putianyi889 Oct 31, 2024
ebe820e
Update range.jl
putianyi889 Oct 31, 2024
ed0c891
Merge branch 'master' into patch-1
putianyi889 Nov 1, 2024
466ad24
Merge branch 'master' into patch-1
putianyi889 Nov 2, 2024
c28f960
Update abstractarray.jl
putianyi889 Nov 2, 2024
ba37c5f
Merge branch 'master' into patch-1
putianyi889 Nov 4, 2024
00905cb
Merge branch 'master' into patch-1
putianyi889 Nov 7, 2024
1163642
Merge branch 'master' into patch-1
putianyi889 Nov 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 1 addition & 7 deletions base/abstractarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1240,13 +1240,7 @@ isempty(a::AbstractArray) = (length(a) == 0)


## range conversions ##

map(::Type{T}, r::StepRange) where {T<:Real} = T(r.start):T(r.step):T(last(r))
map(::Type{T}, r::UnitRange) where {T<:Real} = T(r.start):T(last(r))
map(::Type{T}, r::StepRangeLen) where {T<:AbstractFloat} = convert(StepRangeLen{T}, r)
function map(::Type{T}, r::LinRange) where T<:AbstractFloat
LinRange(T(r.start), T(r.stop), length(r))
end
map(::Type{T}, r::AbstractRange) where {T<:Real} = AbstractArray{T}(r)

## unsafe/pointer conversions ##

Expand Down
13 changes: 13 additions & 0 deletions base/range.jl
Original file line number Diff line number Diff line change
Expand Up @@ -298,6 +298,8 @@ Supertype for ranges with a step size of [`oneunit(T)`](@ref) with elements of t
"""
abstract type AbstractUnitRange{T} <: OrdinalRange{T,T} end

AbstractRange{T}(r::AbstractUnitRange) where {T<:Integer} = AbstractUnitRange{T}(r)

"""
StepRange{T, S} <: OrdinalRange{T, S}

Expand Down Expand Up @@ -1314,6 +1316,8 @@ AbstractUnitRange{T}(r::OneTo) where {T} = OneTo{T}(r)

OrdinalRange{T, S}(r::OrdinalRange) where {T, S} = StepRange{T, S}(r)
OrdinalRange{T, T}(r::AbstractUnitRange) where {T} = AbstractUnitRange{T}(r)
OrdinalRange{T}(r::OrdinalRange{R,S}) where {T, R, S} = OrdinalRange{T, promote_type(T,S)}(r) # type of step matters
OrdinalRange{T}(r::AbstractUnitRange) where T = AbstractUnitRange{T}(r) # not in this case

function promote_rule(::Type{StepRange{T1a,T1b}}, ::Type{StepRange{T2a,T2b}}) where {T1a,T1b,T2a,T2b}
Tb = promote_type(T1b, T2b)
Expand Down Expand Up @@ -1363,6 +1367,15 @@ promote_rule(a::Type{LinRange{T,L}}, ::Type{OR}) where {T,L,OR<:OrdinalRange} =
promote_rule(::Type{LinRange{A,L}}, b::Type{StepRangeLen{T2,R2,S2,L2}}) where {A,L,T2,R2,S2,L2} =
promote_rule(StepRangeLen{A,A,A,L}, b)

AbstractRange{T}(r::AbstractRange) where T = range(T(first(r)), T(last(r)), length(r))

AbstractRange{T}(r::OrdinalRange) where T<:Integer = OrdinalRange{T}(r) # float should fall back to StepRangeLen
AbstractRange{T}(r::StepRangeLen) where T = StepRangeLen{T}(r)
AbstractRange{T}(r::LinRange) where T = LinRange{T}(r)

AbstractArray{T,1}(r::AbstractRange) where T = AbstractRange{T}(r)
AbstractArray{T}(r::AbstractRange) where T = AbstractRange{T}(r)

## concatenation ##

function vcat(rs::AbstractRange{T}...) where T
Expand Down
18 changes: 18 additions & 0 deletions test/ranges.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1320,6 +1320,24 @@ end
@test eltype(['a':'z', 1:2]) == (StepRange{T,Int} where T)
end

@testset "Eltype conversion (PR #48894)" begin
# StepRangeLen
@test 0.:5. isa StepRangeLen # just in case
@test convert(AbstractRange{Int},0.:5.) === convert(AbstractVector{Int},0.:5.) === convert(AbstractArray{Int},0.:5.) === StepRangeLen(0,1,6)
@test convert(AbstractRange{Float16},0.:5.) === convert(AbstractVector{Float16},0.:5.) === convert(AbstractArray{Float16},0.:5.) === Float16(0.):Float16(5.)

# Try to preserve type when possible
@test AbstractArray{Int8}(Base.oneto(5)) === Base.oneto(Int8(5)) # OneTo
@test AbstractArray{Int32}(0:5) === Int32(0):Int32(5) # UnitRange
@test AbstractArray{Int128}(0:2:5) === Int128(0):Int128(2):4 # StepRange
@test AbstractArray{Float64}(LinRange(1,5,5)) === LinRange(1.0,5.0,5) # LinRange
@test AbstractArray{Float64}(Base.oneto(5)) === AbstractArray{Float64}(1:5) === AbstractArray{Float64}(1:1:5) === 1.:1.:5. # fallback

# Edge cases where floating point can be glitchy. Credit: @mcabbott
@test convert(AbstractArray{Float64}, 0*(1:10)) === range(0.0,0.0,10)
@test length(convert(AbstractArray{Float16}, range(1/43^2, 1, 43))) == 43
end

@testset "Ranges with <:Integer eltype but non-integer step (issue #32419)" begin
@test eltype(StepRange(1, 1//1, 2)) === Int
@test_throws ArgumentError StepRange(1, 1//2, 2)
Expand Down