diff --git a/base/array.jl b/base/array.jl index 53cb97ed7fe17..3bb6c89d00e7a 100644 --- a/base/array.jl +++ b/base/array.jl @@ -942,7 +942,7 @@ function resize!(a::Vector, nl::Integer) l = length(a) if nl > l ccall(:jl_array_grow_end, Cvoid, (Any, UInt), a, nl-l) - else + elseif nl != l if nl < 0 throw(ArgumentError("new length must be ≥ 0")) end diff --git a/src/array.c b/src/array.c index 54574dbe55f0a..b139b0935429f 100644 --- a/src/array.c +++ b/src/array.c @@ -1022,6 +1022,8 @@ JL_DLLEXPORT void jl_array_del_beg(jl_array_t *a, size_t dec) jl_bounds_error_int((jl_value_t*)a, dec); if (__unlikely(a->flags.isshared)) array_try_unshare(a); + if (dec == 0) + return; jl_array_del_at_beg(a, 0, dec, n); } @@ -1032,6 +1034,8 @@ JL_DLLEXPORT void jl_array_del_end(jl_array_t *a, size_t dec) jl_bounds_error_int((jl_value_t*)a, 0); if (__unlikely(a->flags.isshared)) array_try_unshare(a); + if (dec == 0) + return; jl_array_del_at_end(a, n - dec, dec, n); } diff --git a/test/strings/basic.jl b/test/strings/basic.jl index 67cdf5e0f92c1..030fa3be66f06 100644 --- a/test/strings/basic.jl +++ b/test/strings/basic.jl @@ -8,6 +8,17 @@ using Random @test String("abc!") == "abc!" @test String(0x61:0x63) == "abc" + # Check that resizing empty source vector does not corrupt string + b = IOBuffer() + write(b, "ab") + x = take!(b) + s = String(x) + resize!(x, 0) + empty!(x) # Another method which must be tested + @test s == "ab" + resize!(x, 1) + @test s == "ab" + @test isempty(string()) @test eltype(GenericString) == Char @test firstindex("abc") == 1