Skip to content

Commit

Permalink
Fix unsigned wrap around in lpad/rpad/string allocation (#32161)
Browse files Browse the repository at this point in the history
Fixes #32160

(cherry picked from commit 86bc521)
  • Loading branch information
c42f authored and KristofferC committed Jun 9, 2019
1 parent d2e2ea9 commit 28c2b0d
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 2 deletions.
4 changes: 2 additions & 2 deletions base/strings/util.jl
Original file line number Diff line number Diff line change
Expand Up @@ -245,7 +245,7 @@ function lpad(
n::Integer,
p::Union{AbstractChar,AbstractString}=' ',
) :: String
m = n - length(s)
m = signed(n) - length(s)
m 0 && return string(s)
l = length(p)
q, r = divrem(m, l)
Expand All @@ -272,7 +272,7 @@ function rpad(
n::Integer,
p::Union{AbstractChar,AbstractString}=' ',
) :: String
m = n - length(s)
m = signed(n) - length(s)
m 0 && return string(s)
l = length(p)
q, r = divrem(m, l)
Expand Down
4 changes: 4 additions & 0 deletions src/array.c
Original file line number Diff line number Diff line change
Expand Up @@ -470,6 +470,8 @@ JL_DLLEXPORT jl_value_t *jl_array_to_string(jl_array_t *a)
JL_DLLEXPORT jl_value_t *jl_pchar_to_string(const char *str, size_t len)
{
size_t sz = sizeof(size_t) + len + 1; // add space for trailing \nul protector and size
if (sz < len) // overflow
jl_throw(jl_memory_exception);
if (len == 0)
return jl_an_empty_string;
jl_value_t *s = jl_gc_alloc_(jl_get_ptls_states(), sz, jl_string_type); // force inlining
Expand All @@ -482,6 +484,8 @@ JL_DLLEXPORT jl_value_t *jl_pchar_to_string(const char *str, size_t len)
JL_DLLEXPORT jl_value_t *jl_alloc_string(size_t len)
{
size_t sz = sizeof(size_t) + len + 1; // add space for trailing \nul protector and size
if (sz < len) // overflow
jl_throw(jl_memory_exception);
if (len == 0)
return jl_an_empty_string;
jl_value_t *s = jl_gc_alloc_(jl_get_ptls_states(), sz, jl_string_type); // force inlining
Expand Down
2 changes: 2 additions & 0 deletions test/strings/basic.jl
Original file line number Diff line number Diff line change
Expand Up @@ -606,6 +606,8 @@ end
@test repeat(s, 3) === S
@test repeat(S, 3) === S*S*S
end
# Issue #32160 (string allocation unsigned overflow)
@test_throws OutOfMemoryError repeat('x', typemax(Csize_t))
end
@testset "issue #12495: check that logical indexing attempt raises ArgumentError" begin
@test_throws ArgumentError "abc"[[true, false, true]]
Expand Down
3 changes: 3 additions & 0 deletions test/strings/util.jl
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@
@test rpad("αβ", 8, "¹₂³") == "αβ¹₂³¹₂³"
@test lpad("αβ", 9, "¹₂³") == "¹₂³¹₂³¹αβ"
@test rpad("αβ", 9, "¹₂³") == "αβ¹₂³¹₂³¹"
# Issue #32160 (unsigned underflow in lpad/rpad)
@test lpad("xx", UInt(1), " ") == "xx"
@test rpad("xx", UInt(1), " ") == "xx"
end

# string manipulation
Expand Down

0 comments on commit 28c2b0d

Please sign in to comment.