Skip to content

Commit

Permalink
Fix overflow in JuliaLang#5550.
Browse files Browse the repository at this point in the history
  • Loading branch information
mschauer committed Jan 26, 2014
1 parent 9bd4618 commit 3304e86
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions base/random.jl
Original file line number Diff line number Diff line change
Expand Up @@ -157,10 +157,10 @@ rand{T<:Number}(::Type{T}, dims::Int...) = rand(T, dims)

immutable RandIntGen{T<:Integer, U<:Unsigned}
a::T # first element of the range
k::U # range length
k::U # range length or 0 for full range
u::U # maximum multiple of k within the domain of U

RandIntGen(a::T, k::U) = new(a, k, div(typemax(U),k)*k)
RandIntGen(a::T, k::U) = new(a, k, k == 0 ? k : div(typemax(U),k)*k)
end

RandIntGen{T<:Unsigned}(r::Range1{T}) = RandIntGen{T,T}(first(r), convert(T, length(r)))
Expand All @@ -170,11 +170,12 @@ for (T, U) in [(Uint8, Uint32), (Uint16, Uint32), (Int8, Uint32), (Int16, Uint32
(Int32, Uint32), (Int64, Uint64), (Int128, Uint128),
(Bool, Uint32), (Char, Uint32)]

@eval RandIntGen(r::Range1{$T}) = RandIntGen{$T, $U}(first(r), convert($U, length(r)))
@eval RandIntGen(r::Range1{$T}) = RandIntGen{$T, $U}(first(r), convert($U, length(r))) # allow overflow when length(r) == typemax(U)
end

function rand{T<:Integer,U<:Unsigned}(g::RandIntGen{T,U})
x = rand(U)
k == 0 || return convert(T, g.a + x)
while x >= g.u
x = rand(U)
end
Expand Down

0 comments on commit 3304e86

Please sign in to comment.