2 * This file is open source software, licensed to you under the terms
3 * of the Apache License, Version 2.0 (the "License"). See the NOTICE file
4 * distributed with this work for additional information regarding copyright
5 * ownership. You may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing,
12 * software distributed under the License is distributed on an
13 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14 * KIND, either express or implied. See the License for the
15 * specific language governing permissions and limitations
19 * Copyright (C) 2014 Cloudius Systems, Ltd.
24 #include <type_traits>
27 #include <seastar/util/concepts.hh>
29 #ifdef SEASTAR_DEFERRED_ACTION_REQUIRE_NOEXCEPT
30 #define SEASTAR_DEFERRED_ACTION_NOEXCEPT noexcept
32 #define SEASTAR_DEFERRED_ACTION_NOEXCEPT
36 template <typename Func>
37 concept deferrable_action = requires (Func func) {
38 { func() } SEASTAR_DEFERRED_ACTION_NOEXCEPT -> std::same_as<void>;
44 template <typename Func>
45 SEASTAR_CONCEPT( requires deferrable_action<Func> )
46 class [[nodiscard("unassigned deferred_action")]] deferred_action {
48 bool _cancelled = false;
50 static_assert(std::is_nothrow_move_constructible<Func>::value, "Func(Func&&) must be noexcept");
51 deferred_action(Func&& func) noexcept : _func(std::move(func)) {}
52 deferred_action(deferred_action&& o) noexcept : _func(std::move(o._func)), _cancelled(o._cancelled) {
55 deferred_action& operator=(deferred_action&& o) noexcept {
57 this->~deferred_action();
58 new (this) deferred_action(std::move(o));
62 deferred_action(const deferred_action&) = delete;
63 ~deferred_action() { if (!_cancelled) { _func(); }; }
64 void cancel() { _cancelled = true; }
67 template <typename Func>
68 SEASTAR_CONCEPT( requires deferrable_action<Func> )
72 return deferred_action<Func>(std::forward<Func>(func));