[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / libcxx / test / std / thread / futures / futures.task / futures.task.members / get_future.pass.cpp
blob7c5931d18bc30c98a44912b1a32b53aa046ed2f5
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // UNSUPPORTED: no-threads
10 // UNSUPPORTED: c++03
12 // <future>
14 // class packaged_task<R(ArgTypes...)>
16 // future<R> get_future();
18 #include <future>
19 #include <cassert>
21 #include "test_macros.h"
23 class A
25 long data_;
27 public:
28 explicit A(long i) : data_(i) {}
30 long operator()(long i, long j) const {return data_ + i + j;}
33 int main(int, char**)
36 std::packaged_task<double(int, char)> p(A(5));
37 std::future<double> f = p.get_future();
38 p(3, 97);
39 assert(f.get() == 105.0);
41 #ifndef TEST_HAS_NO_EXCEPTIONS
43 std::packaged_task<double(int, char)> p(A(5));
44 std::future<double> f = p.get_future();
45 try
47 f = p.get_future();
48 assert(false);
50 catch (const std::future_error& e)
52 assert(e.code() == make_error_code(std::future_errc::future_already_retrieved));
56 std::packaged_task<double(int, char)> p;
57 try
59 std::future<double> f = p.get_future();
60 assert(false);
62 catch (const std::future_error& e)
64 assert(e.code() == make_error_code(std::future_errc::no_state));
67 #endif
69 return 0;