From 5e489531c1e0915d09fd5984a1a7c0df6fb16ff5 Mon Sep 17 00:00:00 2001 From: Orivej Desh Date: Tue, 8 Oct 2019 09:09:38 +0000 Subject: [PATCH 1/3] Fix undefined in core-test Fixes "reference binding to null pointer" in BufferTest.Ctor buffer.operator[] attempts to return a reference to `buffer.ptr_[0]` when `ptr_` in `mock_buffer buffer` is null. --- test/core-test.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/core-test.cc b/test/core-test.cc index 84d2b9eb0172..76612b9914db 100644 --- a/test/core-test.cc +++ b/test/core-test.cc @@ -103,7 +103,7 @@ template struct mock_buffer : buffer { TEST(BufferTest, Ctor) { { mock_buffer buffer; - EXPECT_EQ(nullptr, &buffer[0]); + EXPECT_EQ(nullptr, buffer.data()); EXPECT_EQ(static_cast(0), buffer.size()); EXPECT_EQ(static_cast(0), buffer.capacity()); } From 1bb56544ae15be58fabe3af820d9a7ce5028da3e Mon Sep 17 00:00:00 2001 From: Orivej Desh Date: Tue, 8 Oct 2019 09:10:18 +0000 Subject: [PATCH 2/3] Fix undefined in printf-test Fixes "signed integer overflow" in PrintfTest.Length This occurs in `TestLength("ll")`, since its minimum value minus one does not fit in long long. --- test/printf-test.cc | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/test/printf-test.cc b/test/printf-test.cc index cd9950d170b0..d8fbc9649aec 100644 --- a/test/printf-test.cc +++ b/test/printf-test.cc @@ -337,7 +337,9 @@ template void TestLength(const char* length_spec) { TestLength(length_spec, -42); TestLength(length_spec, min); TestLength(length_spec, max); - TestLength(length_spec, static_cast(min) - 1); + long long long_long_min = std::numeric_limits::min(); + if (static_cast(min) > long_long_min) + TestLength(length_spec, static_cast(min) - 1); unsigned long long long_long_max = max_value(); if (static_cast(max) < long_long_max) TestLength(length_spec, static_cast(max) + 1); From 66936d3e8ff691e0f1536b7f2bb39bcf1df0eee6 Mon Sep 17 00:00:00 2001 From: Orivej Desh Date: Tue, 8 Oct 2019 09:10:51 +0000 Subject: [PATCH 3/3] Fix undefined in printf %0$ Printf counts arguments from 1. Fixes "shift exponent -4 is negative" in PrintfTest.InvalidArgIndex. `do_get` is called with index -1 when `basic_printf_context.arg` is called with id 4294967295 when basic_printf_context::get_arg subtracts 1 from arg_index 0 in the format string "%0$d". --- include/fmt/printf.h | 2 ++ test/printf-test.cc | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/include/fmt/printf.h b/include/fmt/printf.h index 18f8d1211dcc..6c7e328f7574 100644 --- a/include/fmt/printf.h +++ b/include/fmt/printf.h @@ -469,6 +469,8 @@ OutputIt basic_printf_context::format() { // Parse argument index, flags and width. unsigned arg_index = parse_header(it, end, specs); + if (arg_index == 0) + on_error("argument index 0 is out of range"); // Parse precision. if (it != end && *it == '.') { diff --git a/test/printf-test.cc b/test/printf-test.cc index d8fbc9649aec..f158a6274cec 100644 --- a/test/printf-test.cc +++ b/test/printf-test.cc @@ -112,7 +112,7 @@ TEST(PrintfTest, SwitchArgIndexing) { TEST(PrintfTest, InvalidArgIndex) { EXPECT_THROW_MSG(test_sprintf("%0$d", 42), format_error, - "argument index out of range"); + "argument index 0 is out of range"); EXPECT_THROW_MSG(test_sprintf("%2$d", 42), format_error, "argument index out of range"); EXPECT_THROW_MSG(test_sprintf(format("%{}$d", INT_MAX), 42), format_error,