-
-
Notifications
You must be signed in to change notification settings - Fork 183
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Bug 1743020 - Part 3: Export mozilla::MoveOnlyFunction based on funct…
…ion2, r=glandium A custom defintion wrapping fu2::function_base is used to customize the inline buffer's size and alignment to make it compatible with nsTArray. Without the custom wrapper, `alignof(max_align_t)` is used, which is larger than nsTArray's max alignment on some platforms. Differential Revision: https://phabricator.services.mozilla.com/D145691
- Loading branch information
Showing
3 changed files
with
53 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ | ||
/* vim: set ts=8 sts=2 et sw=2 tw=80: */ | ||
/* This Source Code Form is subject to the terms of the Mozilla Public | ||
* License, v. 2.0. If a copy of the MPL was not distributed with this file, | ||
* You can obtain one at http://mozilla.org/MPL/2.0/. */ | ||
|
||
#ifndef mozilla_MoveOnlyFunction_h | ||
#define mozilla_MoveOnlyFunction_h | ||
|
||
// Use stl-like empty propagation to avoid issues with wrapping closures which | ||
// implicitly coerce to bool. | ||
#define FU2_WITH_LIMITED_EMPTY_PROPAGATION | ||
|
||
#include "function2/function2.hpp" | ||
|
||
namespace mozilla { | ||
|
||
/// A type like `std::function`, but with support for move-only callable | ||
/// objects. | ||
/// | ||
/// A similar type is proposed to be added to the standard library as | ||
/// `std::move_only_function` in C++23. | ||
/// | ||
/// Unlike `std::function`, the function signature may be given const or | ||
/// reference qualifiers which will be applied to `operator()`. This can be used | ||
/// to declare const qualified or move-only functions. | ||
/// | ||
/// The implementation this definition depends on (function2) also has support | ||
/// for callables with overload sets, however support for this was not exposed | ||
/// to align better with the proposed `std::move_only_function`, which does not | ||
/// support overload sets. | ||
/// | ||
/// A custom typedef over `fu2::function_base` is used to control the size and | ||
/// alignment of the inline storage to store 2 aligned pointers, and ensure the | ||
/// type is compatible with `nsTArray`. | ||
template <typename Signature> | ||
using MoveOnlyFunction = fu2::function_base< | ||
/* IsOwning */ true, | ||
/* IsCopyable */ false, | ||
/* Capacity */ fu2::capacity_fixed<2 * sizeof(void*), alignof(void*)>, | ||
/* IsThrowing */ false, | ||
/* HasStrongExceptionGuarantee */ false, | ||
/* Signature */ Signature>; | ||
|
||
} // namespace mozilla | ||
|
||
#endif // mozilla_MoveOnlyFunction_h |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters