summaryrefslogtreecommitdiff
path: root/meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch')
-rw-r--r--meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch140
1 files changed, 140 insertions, 0 deletions
diff --git a/meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch b/meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch
new file mode 100644
index 000000000..f3ee5923a
--- /dev/null
+++ b/meta/recipes-devtools/gcc/gcc-4.6.0/gcc-4_6-branch-backports/0076-Merge-r172073-from-trunk-to-the-4.6-release-branch-t.patch
@@ -0,0 +1,140 @@
+From 3329b7447ab817bb0374a689f3b381a5781ed8aa Mon Sep 17 00:00:00 2001
+From: jyasskin <jyasskin@138bc75d-0d04-0410-961f-82ee72b054a4>
+Date: Thu, 7 Apr 2011 04:50:23 +0000
+Subject: [PATCH 076/200] Merge r172073 from trunk to the 4.6 release branch, to fix two
+ ambiguities between extensions and new C++0x functions.
+
+Tested: bootstrap + make check-c++ on x86_64
+
+libstdc++-v3/ChangeLog:
+
+2011-04-06 Jeffrey Yasskin <jyasskin@google.com>
+
+ * include/ext/algorithm (is_sorted): In C++0x mode import from
+ namespace std.
+ * include/ext/numeric (iota): In C++0x mode import from
+ namespace std.
+ * testsuite/ext/is_sorted/cxx0x.cc: New.
+ * testsuite/ext/iota/cxx0x.cc: New.
+
+
+
+git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_6-branch@172074 138bc75d-0d04-0410-961f-82ee72b054a4
+
+index 368b591..417a03a 100644
+--- a/libstdc++-v3/include/ext/algorithm
++++ b/libstdc++-v3/include/ext/algorithm
+@@ -471,6 +471,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ }
+ #endif
+
++#ifdef __GXX_EXPERIMENTAL_CXX0X__
++ using std::is_sorted;
++#else
+ // is_sorted, a predicated testing whether a range is sorted in
+ // nondescending order. This is an extension, not part of the C++
+ // standard.
+@@ -526,6 +529,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ return false;
+ return true;
+ }
++#endif // __GXX_EXPERIMENTAL_CXX0X__
+
+ /**
+ * @brief Find the median of three values.
+diff --git a/libstdc++-v3/include/ext/numeric b/libstdc++-v3/include/ext/numeric
+index d4a367f..b389177 100644
+--- a/libstdc++-v3/include/ext/numeric
++++ b/libstdc++-v3/include/ext/numeric
+@@ -123,6 +123,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ power(_Tp __x, _Integer __n)
+ { return __power(__x, __n); }
+
++#ifdef __GXX_EXPERIMENTAL_CXX0X__
++ using std::iota;
++#else
+ /**
+ * This is an SGI extension.
+ * @ingroup SGIextensions
+@@ -141,9 +144,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ while (__first != __last)
+ *__first++ = __value++;
+ }
++#endif // __GXX_EXPERIMENTAL_CXX0X__
+
+ _GLIBCXX_END_NAMESPACE_VERSION
+ } // namespace
+
+ #endif
+-
+diff --git a/libstdc++-v3/testsuite/ext/iota/cxx0x.cc b/libstdc++-v3/testsuite/ext/iota/cxx0x.cc
+new file mode 100644
+index 0000000..84917ad
+--- /dev/null
++++ b/libstdc++-v3/testsuite/ext/iota/cxx0x.cc
+@@ -0,0 +1,28 @@
++// { dg-do compile }
++// { dg-options "-std=gnu++0x" }
++
++// Copyright (C) 2011 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
++// <http://www.gnu.org/licenses/>.
++
++#include <ext/numeric>
++#include <vector>
++
++void foo()
++{
++ std::vector<int> v;
++ iota(v.begin(), v.end(), 0);
++}
+diff --git a/libstdc++-v3/testsuite/ext/is_sorted/cxx0x.cc b/libstdc++-v3/testsuite/ext/is_sorted/cxx0x.cc
+new file mode 100644
+index 0000000..518716c
+--- /dev/null
++++ b/libstdc++-v3/testsuite/ext/is_sorted/cxx0x.cc
+@@ -0,0 +1,28 @@
++// { dg-do compile }
++// { dg-options "-std=gnu++0x" }
++
++// Copyright (C) 2011 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
++// <http://www.gnu.org/licenses/>.
++
++#include <ext/algorithm>
++#include <vector>
++
++void foo()
++{
++ std::vector<int> v;
++ is_sorted(v.begin(), v.end());
++}
+--
+1.7.0.4
+