diff options
| author | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-09-09 17:56:51 +0000 |
|---|---|---|
| committer | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-09-09 17:56:51 +0000 |
| commit | 885804958977ee33c50f78fdb28b1a992fdcde56 (patch) | |
| tree | 9a602af81e687d5ca4c3dd7a733930b7460808f1 /libstdc++-v3/include/std/array | |
| parent | 724462b06920593c5899703a0547f6052ec9d973 (diff) | |
| download | ppe42-gcc-885804958977ee33c50f78fdb28b1a992fdcde56.tar.gz ppe42-gcc-885804958977ee33c50f78fdb28b1a992fdcde56.zip | |
PR libstdc++/54388
* include/std/array (array::at() const): Ensure lvalue result.
* testsuite/23_containers/array/element_access/54388.cc: New.
* testsuite/23_containers/array/tuple_interface/get_neg.cc: Adjust
dg-error line numbers.
* testsuite/23_containers/array/tuple_interface/tuple_element_neg.cc:
Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@191114 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/include/std/array')
| -rw-r--r-- | libstdc++-v3/include/std/array | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/libstdc++-v3/include/std/array b/libstdc++-v3/include/std/array index 58263ce418a..4ee21998b01 100644 --- a/libstdc++-v3/include/std/array +++ b/libstdc++-v3/include/std/array @@ -164,22 +164,14 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION return _M_instance[__n]; } -#ifdef __EXCEPTIONS constexpr const_reference at(size_type __n) const { - return __n < _Nm ? - _M_instance[__n] : throw out_of_range(__N("array::at")); + // Result of conditional expression must be an lvalue so use + // boolean ? lvalue : (throw-expr, lvalue) + return __n < _Nm ? _M_instance[__n] + : (std::__throw_out_of_range(__N("array::at")), _M_instance[0]); } -#else - const_reference - at(size_type __n) const - { - if (__n >= _Nm) - std::__throw_out_of_range(__N("array::at")); - return _M_instance[__n]; - } -#endif reference front() |

