2 * Copyright 2016 Facebook, Inc.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
22 #include <folly/futures/FutureException.h>
23 #include <folly/futures/detail/Core.h>
28 Promise<T>::Promise() : retrieved_(false), core_(new detail::Core<T>())
32 Promise<T>::Promise(Promise<T>&& other) noexcept
33 : retrieved_(other.retrieved_), core_(other.core_) {
34 other.core_ = nullptr;
35 other.retrieved_ = false;
39 Promise<T>& Promise<T>::operator=(Promise<T>&& other) noexcept {
40 std::swap(core_, other.core_);
41 std::swap(retrieved_, other.retrieved_);
46 void Promise<T>::throwIfFulfilled() {
47 if (UNLIKELY(!core_)) {
50 if (UNLIKELY(core_->ready())) {
51 throw PromiseAlreadySatisfied();
56 void Promise<T>::throwIfRetrieved() {
57 if (UNLIKELY(retrieved_)) {
58 throw FutureAlreadyRetrieved();
63 Promise<T>::~Promise() {
68 void Promise<T>::detach() {
71 core_->detachFuture();
72 core_->detachPromise();
78 Future<T> Promise<T>::getFuture() {
81 return Future<T>(core_);
86 typename std::enable_if<std::is_base_of<std::exception, E>::value>::type
87 Promise<T>::setException(E const& e) {
88 setException(make_exception_wrapper<E>(e));
92 void Promise<T>::setException(std::exception_ptr const& ep) {
94 std::rethrow_exception(ep);
95 } catch (const std::exception& e) {
96 setException(exception_wrapper(std::current_exception(), e));
98 setException(exception_wrapper(std::current_exception()));
103 void Promise<T>::setException(exception_wrapper ew) {
105 core_->setResult(Try<T>(std::move(ew)));
109 void Promise<T>::setInterruptHandler(
110 std::function<void(exception_wrapper const&)> fn) {
111 core_->setInterruptHandler(std::move(fn));
115 void Promise<T>::setTry(Try<T>&& t) {
117 core_->setResult(std::move(t));
122 void Promise<T>::setValue(M&& v) {
123 static_assert(!std::is_same<T, void>::value,
124 "Use setValue() instead");
126 setTry(Try<T>(std::forward<M>(v)));
131 void Promise<T>::setWith(F&& func) {
133 setTry(makeTryWith(std::forward<F>(func)));
137 bool Promise<T>::isFulfilled() {
139 return core_->hasResult();