diff --git a/base/abstractarraymath.jl b/base/abstractarraymath.jl index 874a2215892bb1..54b6d75cee2dca 100644 --- a/base/abstractarraymath.jl +++ b/base/abstractarraymath.jl @@ -432,7 +432,7 @@ julia> repeat([1, 2, 3], 2, 3) 3 3 3 ``` """ -function repeat(A::AbstractArray, counts::Integer...) +function repeat(A::AbstractArray, counts...) return repeat(A, outer=counts) end @@ -518,6 +518,9 @@ function check(arr, inner, outer) # TODO: Currently one based indexing is demanded for inner !== nothing, # but not for outer !== nothing. Decide for something consistent. Base.require_one_based_indexing(arr) + if !all(n -> n isa Integer, inner) + throw(ArgumentError("repeat requires integer counts, got inner = $inner")) + end if any(<(0), inner) throw(ArgumentError("no inner repetition count may be negative; got $inner")) end @@ -526,6 +529,9 @@ function check(arr, inner, outer) end end if outer !== nothing + if !all(n -> n isa Integer, outer) + throw(ArgumentError("repeat requires integer counts, got outer = $outer")) + end if any(<(0), outer) throw(ArgumentError("no outer repetition count may be negative; got $outer")) end