Define std::thread::id comparison operators at namespace-scope
authorJonathan Wakely <jwakely@redhat.com>
Mon, 18 Apr 2016 16:16:14 +0000 (17:16 +0100)
committerJonathan Wakely <redi@gcc.gnu.org>
Mon, 18 Apr 2016 16:16:14 +0000 (17:16 +0100)
From-SVN: r235155

libstdc++-v3/ChangeLog
libstdc++-v3/include/std/thread
libstdc++-v3/testsuite/30_threads/thread/id/70294.cc [new file with mode: 0644]

index 385363bda881f3bdd5ae21bf927bc869e5e06289..14c1c2c92c888a8f059c1d02a0ca7ccb51ef6d4f 100644 (file)
@@ -1,5 +1,10 @@
 2016-04-18  Jonathan Wakely  <jwakely@redhat.com>
 
+       PR libstdc++/70294
+       * include/std/thread (operator<, operator==): Move definitions to
+       namespace-scope.
+       * testsuite/30_threads/thread/id/70294.cc: New test.
+
        * testsuite/18_support/bad_exception/23591_thread-1.c: Add
        -Wno-pedantic to dg-options.
        * testsuite/20_util/align/2.cc: Use type as operand of alignof.
index ad31fbc456f5d9aeb2913f3f00bff4945b4db451..15aa9a9b577ea6ad56240e109900cbf312fe2721 100644 (file)
@@ -88,22 +88,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
       friend class hash<thread::id>;
 
       friend bool
-      operator==(thread::id __x, thread::id __y) noexcept
-      {
-       // pthread_equal is undefined if either thread ID is not valid, so we
-       // can't safely use __gthread_equal on default-constructed values (nor
-       // the non-zero value returned by this_thread::get_id() for
-       // single-threaded programs using GNU libc). Assume EqualityComparable.
-       return __x._M_thread == __y._M_thread;
-      }
+      operator==(thread::id __x, thread::id __y) noexcept;
 
       friend bool
-      operator<(thread::id __x, thread::id __y) noexcept
-      {
-       // Pthreads doesn't define any way to do this, so we just have to
-       // assume native_handle_type is LessThanComparable.
-       return __x._M_thread < __y._M_thread;
-      }
+      operator<(thread::id __x, thread::id __y) noexcept;
 
       template<class _CharT, class _Traits>
        friend basic_ostream<_CharT, _Traits>&
@@ -230,10 +218,28 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
   swap(thread& __x, thread& __y) noexcept
   { __x.swap(__y); }
 
+  inline bool
+  operator==(thread::id __x, thread::id __y) noexcept
+  {
+    // pthread_equal is undefined if either thread ID is not valid, so we
+    // can't safely use __gthread_equal on default-constructed values (nor
+    // the non-zero value returned by this_thread::get_id() for
+    // single-threaded programs using GNU libc). Assume EqualityComparable.
+    return __x._M_thread == __y._M_thread;
+  }
+
   inline bool
   operator!=(thread::id __x, thread::id __y) noexcept
   { return !(__x == __y); }
 
+  inline bool
+  operator<(thread::id __x, thread::id __y) noexcept
+  {
+    // Pthreads doesn't define any way to do this, so we just have to
+    // assume native_handle_type is LessThanComparable.
+    return __x._M_thread < __y._M_thread;
+  }
+
   inline bool
   operator<=(thread::id __x, thread::id __y) noexcept
   { return !(__y < __x); }
diff --git a/libstdc++-v3/testsuite/30_threads/thread/id/70294.cc b/libstdc++-v3/testsuite/30_threads/thread/id/70294.cc
new file mode 100644 (file)
index 0000000..9717637
--- /dev/null
@@ -0,0 +1,24 @@
+// Copyright (C) 2016 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/>.
+
+// { dg-options "-std=gnu++11" }
+// { dg-do compile }
+
+#include <thread>
+
+bool (*lt)(std::thread::id, std::thread::id) = &std::operator<;
+bool (*eq)(std::thread::id, std::thread::id) = &std::operator==;