aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3/include/std/condition_variable
diff options
context:
space:
mode:
authorMike Crowe <mac@mcrowe.com>2018-09-25 14:59:27 +0000
committerJonathan Wakely <redi@gcc.gnu.org>2018-09-25 15:59:27 +0100
commit29b26763f5552129996bfc732cfa2087d7c9657c (patch)
tree1d265f68cd21caedae6be5605e63d2b06c8fd815 /libstdc++-v3/include/std/condition_variable
parent16d30bbd4dae88ceb08bf8b965c8fd61b25b558c (diff)
downloadgcc-29b26763f5552129996bfc732cfa2087d7c9657c.zip
gcc-29b26763f5552129996bfc732cfa2087d7c9657c.tar.gz
gcc-29b26763f5552129996bfc732cfa2087d7c9657c.tar.bz2
Use steady_clock to implement condition_variable::wait_for with predicate
In r263225 (d2e378182a12d68fe5caeffae681252662a2fe7b), I fixed condition_variable::wait_for to use std::chrono::steady_clock for the wait. Unfortunately, I failed to spot that the same fix is required for the wait_for variant that takes a predicate too. 2018-09-25 Mike Crowe <mac@mcrowe.com> * include/std/condition_variable (condition_variable::wait_for): Use steady clock in overload that uses a predicate. From-SVN: r264575
Diffstat (limited to 'libstdc++-v3/include/std/condition_variable')
-rw-r--r--libstdc++-v3/include/std/condition_variable5
1 files changed, 3 insertions, 2 deletions
diff --git a/libstdc++-v3/include/std/condition_variable b/libstdc++-v3/include/std/condition_variable
index 1f84ea3..8417301 100644
--- a/libstdc++-v3/include/std/condition_variable
+++ b/libstdc++-v3/include/std/condition_variable
@@ -158,11 +158,12 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
const chrono::duration<_Rep, _Period>& __rtime,
_Predicate __p)
{
- using __dur = typename __clock_t::duration;
+ using __dur = typename __steady_clock_t::duration;
auto __reltime = chrono::duration_cast<__dur>(__rtime);
if (__reltime < __rtime)
++__reltime;
- return wait_until(__lock, __clock_t::now() + __reltime, std::move(__p));
+ return wait_until(__lock, __steady_clock_t::now() + __reltime,
+ std::move(__p));
}
native_handle_type