forked from facebook/react-native
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSharedFunction.h
More file actions
62 lines (50 loc) · 1.89 KB
/
SharedFunction.h
File metadata and controls
62 lines (50 loc) · 1.89 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#include <functional>
#include <memory>
#include <mutex>
#include <better/mutex.h>
namespace facebook {
namespace react {
/*
* `SharedFunction` implements a pattern of a shared callable object that
* contains the same executable inside. It's similar to `std::function` with
* one important difference: when the object is copied, the stored function (and
* captured values) are shared between instances (not copied). `SharedFunction`
* can be stored inside `std::function` because it's callable. It useful in some
* scenarios, such as:
* - When captured by `std::function` arguments are not copyable;
* - When we need to replace the content of the callable later on the go.
*/
template <typename ReturnT = void, typename... ArgumentT>
class SharedFunction {
using T = ReturnT(ArgumentT...);
struct Pair {
Pair(std::function<T> &&function) : function(std::move(function)) {}
std::function<T> function;
better::shared_mutex mutex{};
};
public:
SharedFunction(std::function<T> &&function = nullptr)
: pair_(std::make_shared<Pair>(std::move(function))) {}
SharedFunction(const SharedFunction &other) = default;
SharedFunction(SharedFunction &&other) noexcept = default;
SharedFunction &operator=(const SharedFunction &other) = default;
SharedFunction &operator=(SharedFunction &&other) noexcept = default;
void assign(std::function<T> function) const {
std::unique_lock<better::shared_mutex> lock(pair_->mutex);
pair_->function = function;
}
ReturnT operator()(ArgumentT... args) const {
std::shared_lock<better::shared_mutex> lock(pair_->mutex);
return pair_->function(args...);
}
private:
std::shared_ptr<Pair> pair_;
};
} // namespace react
} // namespace facebook