From 2decfad7c5df07030c27e70b98ca9feada760d3c Mon Sep 17 00:00:00 2001 From: Eric Fiselier Date: Sat, 18 Jul 2015 23:56:04 +0000 Subject: Fix warnings in array and assoc containers llvm-svn: 242629 --- .../std/containers/sequences/array/array.tuple/get.fail.cpp | 9 ++++++++- .../std/containers/sequences/array/array.tuple/get.pass.cpp | 11 ++++++++--- .../containers/sequences/array/array.tuple/get_const.pass.cpp | 6 +++++- .../containers/sequences/array/array.tuple/get_rv.pass.cpp | 7 +++++-- 4 files changed, 26 insertions(+), 7 deletions(-) (limited to 'libcxx/test/std/containers/sequences/array/array.tuple') diff --git a/libcxx/test/std/containers/sequences/array/array.tuple/get.fail.cpp b/libcxx/test/std/containers/sequences/array/array.tuple/get.fail.cpp index 4f4fbcf93af..ae629bd4daa 100644 --- a/libcxx/test/std/containers/sequences/array/array.tuple/get.fail.cpp +++ b/libcxx/test/std/containers/sequences/array/array.tuple/get.fail.cpp @@ -11,15 +11,22 @@ // template T& get(array& a); +// Prevent -Warray-bounds from issuing a diagnostic when testing with clang verify. +#if defined(__clang__) +#pragma clang diagnostic ignored "-Warray-bounds" +#endif + #include #include +#include "../suppress_array_warnings.h" + int main() { { typedef double T; typedef std::array C; C c = {1, 2, 3.5}; - std::get<3>(c) = 5.5; // Can't get element 3! + std::get<3>(c) = 5.5; // expected-error@array:* {{static_assert failed "Index out of bounds in std::get<> (std::array)"}} } } diff --git a/libcxx/test/std/containers/sequences/array/array.tuple/get.pass.cpp b/libcxx/test/std/containers/sequences/array/array.tuple/get.pass.cpp index d9e242cd420..c4557078fc4 100644 --- a/libcxx/test/std/containers/sequences/array/array.tuple/get.pass.cpp +++ b/libcxx/test/std/containers/sequences/array/array.tuple/get.pass.cpp @@ -14,12 +14,17 @@ #include #include -#if __cplusplus > 201103L +#include "test_macros.h" + +#include "../suppress_array_warnings.h" + + +#if TEST_STD_VER > 11 struct S { std::array a; int k; constexpr S() : a{1,2,3}, k(std::get<2>(a)) {} - }; +}; constexpr std::array getArr () { return { 3, 4 }; } #endif @@ -35,7 +40,7 @@ int main() assert(c[1] == 5.5); assert(c[2] == 3.5); } -#if _LIBCPP_STD_VER > 11 +#if TEST_STD_VER > 11 { typedef double T; typedef std::array C; diff --git a/libcxx/test/std/containers/sequences/array/array.tuple/get_const.pass.cpp b/libcxx/test/std/containers/sequences/array/array.tuple/get_const.pass.cpp index 1cbdfa4ff39..ddc2ab2855c 100644 --- a/libcxx/test/std/containers/sequences/array/array.tuple/get_const.pass.cpp +++ b/libcxx/test/std/containers/sequences/array/array.tuple/get_const.pass.cpp @@ -14,6 +14,10 @@ #include #include +#include "test_macros.h" + +#include "../suppress_array_warnings.h" + int main() { { @@ -24,7 +28,7 @@ int main() assert(std::get<1>(c) == 2); assert(std::get<2>(c) == 3.5); } -#if _LIBCPP_STD_VER > 11 +#if TEST_STD_VER > 11 { typedef double T; typedef std::array C; diff --git a/libcxx/test/std/containers/sequences/array/array.tuple/get_rv.pass.cpp b/libcxx/test/std/containers/sequences/array/array.tuple/get_rv.pass.cpp index 8eec3ceff51..412c7c78aa8 100644 --- a/libcxx/test/std/containers/sequences/array/array.tuple/get_rv.pass.cpp +++ b/libcxx/test/std/containers/sequences/array/array.tuple/get_rv.pass.cpp @@ -11,14 +11,18 @@ // template T&& get(array&& a); +// UNSUPPORTED: c++98, c++03 + #include #include #include #include +#include "../suppress_array_warnings.h" + int main() { -#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES + { typedef std::unique_ptr T; typedef std::array C; @@ -26,5 +30,4 @@ int main() T t = std::get<0>(std::move(c)); assert(*t == 3.5); } -#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES } -- cgit v1.2.3