2018-08-27 07:21:05 -07:00
|
|
|
/**
|
2018-09-11 15:27:47 -07:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2018-08-27 07:21:05 -07:00
|
|
|
*
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <atomic>
|
|
|
|
#include <functional>
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Event Beat serves two interleaving purposes: synchronization of event queues and
|
|
|
|
* ensuring that event dispatching happens on propper threads.
|
|
|
|
*/
|
|
|
|
class EventBeat {
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual ~EventBeat() = default;
|
|
|
|
|
|
|
|
using BeatCallback = std::function<void()>;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Communicates to the Beat that a consumer is waiting for the coming beat.
|
|
|
|
* A consumer must request coming beat after the previous beat happened
|
|
|
|
* to receive a next coming one.
|
|
|
|
*/
|
|
|
|
virtual void request() const;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Induces the next beat to happen as soon as possible. If the method
|
|
|
|
* is called on the proper thread, the beat must happen synchronously.
|
|
|
|
* Subclasses might override this method to implement specific
|
|
|
|
* out-of-turn beat scheduling.
|
|
|
|
* Some types of Event Beats do not support inducing, hence the default
|
|
|
|
* implementation does nothing.
|
|
|
|
* Receiver might ignore the call if a beat was not requested.
|
|
|
|
*/
|
|
|
|
virtual void induce() const;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Sets a callback function.
|
|
|
|
* The callback is must be called on the proper thread.
|
|
|
|
*/
|
|
|
|
void setBeatCallback(const BeatCallback &beatCallback);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/*
|
|
|
|
* Should be used by sublasses to send a beat.
|
|
|
|
* Receiver might ignore the call if a beat was not requested.
|
|
|
|
*/
|
|
|
|
void beat() const;
|
|
|
|
|
|
|
|
BeatCallback beatCallback_;
|
|
|
|
mutable std::atomic<bool> isRequested_ {false};
|
|
|
|
};
|
|
|
|
|
|
|
|
using EventBeatFactory = std::function<std::unique_ptr<EventBeat>()>;
|
|
|
|
|
|
|
|
} // namespace react
|
|
|
|
} // namespace facebook
|