From a524c2e9c6510a58c327c1aae8e6dbe4652854c0 Mon Sep 17 00:00:00 2001 From: Chris Lalancette Date: Wed, 12 Jun 2024 15:15:16 +0000 Subject: [PATCH] Suppress warnings in the benchmarks for upstream GCC false positives. Signed-off-by: Chris Lalancette --- .../test/benchmark/benchmark_bounded_vector.cpp | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/rosidl_runtime_cpp/test/benchmark/benchmark_bounded_vector.cpp b/rosidl_runtime_cpp/test/benchmark/benchmark_bounded_vector.cpp index 97942f701..b578aef08 100644 --- a/rosidl_runtime_cpp/test/benchmark/benchmark_bounded_vector.cpp +++ b/rosidl_runtime_cpp/test/benchmark/benchmark_bounded_vector.cpp @@ -67,7 +67,18 @@ BENCHMARK_F(PerformanceTest, bounded_vector_insert)(benchmark::State & st) for (auto _ : st) { (void)_; v.insert(v.begin(), v2.begin(), v2.end()); +// GCC 13 has false positive warnings around stringop-overflow and array-bounds. +// Suppress them until this is fixed in upstream gcc. See +// https://gcc.gnu.org/bugzilla/show_bug.cgi?id=114758 for more details. +#if defined(__GNUC__) && !defined(__clang__) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wstringop-overflow" +#pragma GCC diagnostic ignored "-Warray-bounds" +#endif v.erase(v.begin()); +#if defined(__GNUC__) && !defined(__clang__) +#pragma GCC diagnostic pop +#endif } }