Skip to content

Commit

Permalink
Remove LambdaPromise debug to avoid compiler errors because of #defin…
Browse files Browse the repository at this point in the history
…e lambda(...).
  • Loading branch information
levlam committed Feb 21, 2024
1 parent 62d87ab commit ba2f63f
Showing 1 changed file with 8 additions and 15 deletions.
23 changes: 8 additions & 15 deletions tdutils/td/utils/Promise.h
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ class LambdaPromise : public PromiseInterface<ValueT> {

public:
void set_value(ValueT &&value) override {
CHECK_IMPL(state_.get() == State::Ready, file_, line_);
CHECK(state_.get() == State::Ready);
do_ok(std::move(value));
state_ = State::Complete;
}
Expand All @@ -116,15 +116,12 @@ class LambdaPromise : public PromiseInterface<ValueT> {
}

template <class FromT>
LambdaPromise(const char *file, int line, FromT &&func)
: func_(std::forward<FromT>(func)), state_(State::Ready), file_(file), line_(line) {
LambdaPromise(FromT &&func) : func_(std::forward<FromT>(func)), state_(State::Ready) {
}

private:
FunctionT func_;
MovableValue<State> state_{State::Empty};
const char *file_ = "";
int line_ = 0;

template <class F = FunctionT>
std::enable_if_t<is_callable<F, Result<ValueT>>::value, void> do_error(Status &&status) {
Expand Down Expand Up @@ -161,12 +158,11 @@ struct is_promise_interface_ptr<unique_ptr<U>> : std::true_type {};

template <class T = void, class F = void, std::enable_if_t<std::is_same<T, void>::value, bool> has_t = false>
auto lambda_promise(F &&f) {
return LambdaPromise<drop_result_t<get_arg_t<std::decay_t<F>>>, std::decay_t<F>>(__FILE__, __LINE__,
std::forward<F>(f));
return LambdaPromise<drop_result_t<get_arg_t<std::decay_t<F>>>, std::decay_t<F>>(std::forward<F>(f));
}
template <class T = void, class F = void, std::enable_if_t<!std::is_same<T, void>::value, bool> has_t = true>
auto lambda_promise(F &&f) {
return LambdaPromise<T, std::decay_t<F>>(__FILE__, __LINE__, std::forward<F>(f));
return LambdaPromise<T, std::decay_t<F>>(std::forward<F>(f));
}

template <class T, class F,
Expand Down Expand Up @@ -329,18 +325,15 @@ class JoinPromise final : public PromiseInterface<Unit> {
class PromiseCreator {
public:
template <class OkT, class ArgT = detail::drop_result_t<detail::get_arg_t<OkT>>>
static Promise<ArgT> lambda_impl(const char *file, int line, OkT &&ok) {
return Promise<ArgT>(
td::make_unique<detail::LambdaPromise<ArgT, std::decay_t<OkT>>>(file, line, std::forward<OkT>(ok)));
static Promise<ArgT> lambda(OkT &&ok) {
return Promise<ArgT>(td::make_unique<detail::LambdaPromise<ArgT, std::decay_t<OkT>>>(std::forward<OkT>(ok)));
}
#define lambda(...) lambda_impl(__FILE__, __LINE__, __VA_ARGS__)

template <class OkT, class ArgT = detail::drop_result_t<detail::get_arg_t<OkT>>>
static auto cancellable_lambda_impl(const char *file, int line, CancellationToken cancellation_token, OkT &&ok) {
static auto cancellable_lambda(CancellationToken cancellation_token, OkT &&ok) {
return Promise<ArgT>(td::make_unique<detail::CancellablePromise<detail::LambdaPromise<ArgT, std::decay_t<OkT>>>>(
std::move(cancellation_token), file, line, std::forward<OkT>(ok)));
std::move(cancellation_token), std::forward<OkT>(ok)));
}
#define cancellable_lambda(...) cancellable_lambda_impl(__FILE__, __LINE__, __VA_ARGS__)

template <class... ArgsT>
static Promise<> join(ArgsT &&...args) {
Expand Down

0 comments on commit ba2f63f

Please sign in to comment.