From e708b94bb76dd6c3d0085bdbe5e4f70d2af11117 Mon Sep 17 00:00:00 2001 From: Jonathan Wakely Date: Tue, 27 Jun 2017 15:44:50 +0100 Subject: [PATCH] PR libstdc++/81221 fix namespace qualification for parallel mode PR libstdc++/81221 * include/bits/stl_algo.h (sample): Qualify with _GLIBCXX_STD_A not std. * testsuite/25_algorithms/sample/81221.cc: New. From-SVN: r249692 --- libstdc++-v3/ChangeLog | 7 ++++++ libstdc++-v3/include/bits/stl_algo.h | 5 ++-- .../testsuite/25_algorithms/sample/81221.cc | 23 +++++++++++++++++++ 3 files changed, 33 insertions(+), 2 deletions(-) create mode 100644 libstdc++-v3/testsuite/25_algorithms/sample/81221.cc diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 6be91fedcc5..6a143cf0fef 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,10 @@ +2017-06-27 Jonathan Wakely + + PR libstdc++/81221 + * include/bits/stl_algo.h (sample): Qualify with _GLIBCXX_STD_A not + std. + * testsuite/25_algorithms/sample/81221.cc: New. + 2017-06-22 Jonathan Wakely PR libstdc++/81173 diff --git a/libstdc++-v3/include/bits/stl_algo.h b/libstdc++-v3/include/bits/stl_algo.h index 246193f38c7..fbebfdbf032 100644 --- a/libstdc++-v3/include/bits/stl_algo.h +++ b/libstdc++-v3/include/bits/stl_algo.h @@ -5831,8 +5831,9 @@ _GLIBCXX_BEGIN_NAMESPACE_ALGO "sample size must be an integer type"); typename iterator_traits<_PopulationIterator>::difference_type __d = __n; - return std::__sample(__first, __last, __pop_cat{}, __out, __samp_cat{}, - __d, std::forward<_UniformRandomBitGenerator>(__g)); + return _GLIBCXX_STD_A:: + __sample(__first, __last, __pop_cat{}, __out, __samp_cat{}, __d, + std::forward<_UniformRandomBitGenerator>(__g)); } #endif // C++17 #endif // C++14 diff --git a/libstdc++-v3/testsuite/25_algorithms/sample/81221.cc b/libstdc++-v3/testsuite/25_algorithms/sample/81221.cc new file mode 100644 index 00000000000..e6dd5e0acd1 --- /dev/null +++ b/libstdc++-v3/testsuite/25_algorithms/sample/81221.cc @@ -0,0 +1,23 @@ +// Copyright (C) 2017 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library is free +// software; you can redistribute it and/or modify it under the +// terms of the GNU General Public License as published by the +// Free Software Foundation; either version 3, or (at your option) +// any later version. + +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. + +// You should have received a copy of the GNU General Public License along +// with this library; see the file COPYING3. If not see +// . + +// { dg-options "-std=gnu++17" } +// { dg-do compile { target c++1z } } + +#undef _GLIBCXX_PARALLEL +#define _GLIBCXX_PARALLEL 1 +#include -- 2.30.2