2010-08-25 17:32:05 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2010-11-16 22:09:02 +00:00
|
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
|
|
// Source Licenses. See LICENSE.TXT for details.
|
2010-08-25 17:32:05 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
// <future>
|
|
|
|
|
|
|
|
// class future_error
|
|
|
|
|
2010-09-04 23:46:48 +00:00
|
|
|
// const char* what() const throw();
|
2010-08-25 17:32:05 +00:00
|
|
|
|
|
|
|
#include <future>
|
|
|
|
#include <cstring>
|
|
|
|
#include <cassert>
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::future_error f(std::make_error_code(std::future_errc::broken_promise));
|
|
|
|
assert(std::strcmp(f.what(), "The associated promise has been destructed prior "
|
|
|
|
"to the associated state becoming ready.") == 0);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
std::future_error f(std::make_error_code(std::future_errc::future_already_retrieved));
|
|
|
|
assert(std::strcmp(f.what(), "The future has already been retrieved from "
|
|
|
|
"the promise or packaged_task.") == 0);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
std::future_error f(std::make_error_code(std::future_errc::promise_already_satisfied));
|
|
|
|
assert(std::strcmp(f.what(), "The state of the promise has already been set.") == 0);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
std::future_error f(std::make_error_code(std::future_errc::no_state));
|
|
|
|
assert(std::strcmp(f.what(), "Operation not permitted on an object without "
|
|
|
|
"an associated state.") == 0);
|
|
|
|
}
|
|
|
|
}
|