From b69c468a37910d03eae0ee7d4711c7f5e3ac583a Mon Sep 17 00:00:00 2001 From: ivarne Date: Mon, 8 Sep 2014 13:02:20 +0200 Subject: [PATCH] Fix #8257 This version of `rand(r::Range)` and `rand!(r::Range,a::AbstractArray)` uses getindex instead of trying to calculate the exact value of the range. This is good because we avoid duplicating the getindex logic in `FloatRange` Also added tests, and fixed a small issue in `in(v, r::Range)` where two calls to step() is not needed --- base/random.jl | 16 ++++------------ base/range.jl | 2 +- test/random.jl | 6 ++++++ 3 files changed, 11 insertions(+), 13 deletions(-) diff --git a/base/random.jl b/base/random.jl index 8cd4d712dbbff2..48cde9269c990c 100644 --- a/base/random.jl +++ b/base/random.jl @@ -207,7 +207,7 @@ function rand{T<:Integer, U<:Unsigned}(g::RandIntGen{T,U}) end rand{T<:Union(Signed,Unsigned,Bool,Char)}(r::UnitRange{T}) = rand(RandIntGen(r)) -rand{T}(r::Range{T}) = convert(T, first(r) + rand(0:(length(r)-1)) * step(r)) +rand{T}(r::Range{T}) = r[rand(1:(length(r)))] function rand!(g::RandIntGen, A::AbstractArray) for i = 1 : length(A) @@ -219,17 +219,9 @@ end rand!{T<:Union(Signed,Unsigned,Bool,Char)}(r::UnitRange{T}, A::AbstractArray) = rand!(RandIntGen(r), A) function rand!{T}(r::Range{T}, A::AbstractArray) - g = RandIntGen(0:(length(r)-1)) - f = first(r) - s = step(r) - if s == 1 - for i = 1 : length(A) - @inbounds A[i] = convert(T, f + rand(g)) - end - else - for i = 1 : length(A) - @inbounds A[i] = convert(T, f + rand(g) * s) - end + g = RandIntGen(1:(length(r))) + for i = 1 : length(A) + @inbounds A[i] = r[rand(g)] end return A end diff --git a/base/range.jl b/base/range.jl index fdfd451b45a14e..b2ebb879aea129 100644 --- a/base/range.jl +++ b/base/range.jl @@ -567,7 +567,7 @@ function map!(f::Callable, dest, r::Range) end function in(x, r::Range) - n = step(r) == zero(step(r)) ? 1 : iround((x-first(r))/step(r))+1 + n = step(r) == 0 ? 1 : iround((x-first(r))/step(r))+1 n >= 1 && n <= length(r) && r[n] == x end diff --git a/test/random.jl b/test/random.jl index 7d0dec2d3d1a59..817803511eb5d3 100644 --- a/test/random.jl +++ b/test/random.jl @@ -165,3 +165,9 @@ a = uuid4() @test_throws ArgumentError UUID("550e8400e29b-41d4-a716-446655440000") @test_throws ArgumentError UUID("550e8400e29b-41d4-a716-44665544000098") @test_throws ArgumentError UUID("z50e8400-e29b-41d4-a716-446655440000") + +#issue 8257 +i8527 = 1:1/3:100 +for i = 1:100 + @test rand(i8257) in i8257 +end