From d15132e9b73ebfb287fd1917ee47e001cef7bcda Mon Sep 17 00:00:00 2001 From: Milan Bouchet-Valat Date: Thu, 26 Jan 2017 14:50:45 +0100 Subject: [PATCH] Restrict signature for getindex(::AbstractString, ::AbstractVector} Only integer indices are supported by the generic interface, so better raise a MethodError for other element types rather than failing later. Ideally the Bool-specific method would not be needed, but it is required as long as Bool<:Integer. --- base/strings/basic.jl | 4 +++- test/strings/basic.jl | 15 +++++++++------ 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/base/strings/basic.jl b/base/strings/basic.jl index d5da3559f7f65..e208f84517379 100644 --- a/base/strings/basic.jl +++ b/base/strings/basic.jl @@ -34,8 +34,10 @@ getindex(s::AbstractString, i::Integer) = s[Int(i)] getindex(s::AbstractString, i::Colon) = s getindex{T<:Integer}(s::AbstractString, r::UnitRange{T}) = s[Int(first(r)):Int(last(r))] # TODO: handle other ranges with stride ±1 specially? -getindex(s::AbstractString, v::AbstractVector) = +getindex{T<:Integer}(s::AbstractString, v::AbstractVector{T}) = sprint(length(v), io->(for i in v; write(io,s[i]) end)) +getindex(s::AbstractString, v::AbstractVector{Bool}) = + throw(ArgumentError("logical indexing not supported for strings")) Symbol(s::AbstractString) = Symbol(String(s)) diff --git a/test/strings/basic.jl b/test/strings/basic.jl index 9048ba7e2036a..e5d264c66b971 100644 --- a/test/strings/basic.jl +++ b/test/strings/basic.jl @@ -172,9 +172,9 @@ gstr = GenericString("12") @test convert(Array{Char,1}, gstr) ==['1';'2'] @test convert(Symbol, gstr)==Symbol("12") -@test getindex(gstr, Bool(1))=='1' -@test getindex(gstr,Bool(1):Bool(1))=="1" -@test getindex(gstr,AbstractVector([Bool(1):Bool(1);]))=="1" +@test gstr[1] == '1' +@test gstr[1:1] == "1" +@test gstr[[1]] == "1" @test done(eachindex("foobar"),7) @test eltype(Base.EachStringIndex) == Int @@ -187,9 +187,8 @@ gstr = GenericString("12") @test length(GenericString(""))==0 -@test getindex(gstr,AbstractVector([Bool(1):Bool(1);]))=="1" - -@test nextind(AbstractArray([Bool(1):Bool(1);]),1)==2 +@test nextind(1:1, 1) == 2 +@test nextind([1], 1) == 2 @test ind2chr(gstr,2)==2 @@ -461,3 +460,7 @@ Base.endof(x::CharStr) = endof(x.chars) # Case with Unicode characters @test cmp("\U1f596\U1f596", CharStr("\U1f596")) == 1 # Gives BoundsError with bug @test cmp(CharStr("\U1f596"), "\U1f596\U1f596") == -1 + +# issue #12495: check that logical indexing attempt raises ArgumentError +@test_throws ArgumentError "abc"[[true, false, true]] +@test_throws ArgumentError "abc"[BitArray([true, false, true])]