mirror of
https://github.com/status-im/react-native.git
synced 2025-02-24 15:18:10 +00:00
Summary: As we did in the previous diff, here we implemented `EventEmitter`'s ownership model as a `shared_ptr`. This change fixes problem with leaking `WeakObject`s which happens on hot-reload. So, in short: * `EventTargetWrapper` object owns `jsi::WeakObject` that can be converted to actual `jsi::Object` that represent event target in JavaScript realm; * `EventTargetWrapper` and `jsi::WeakObject` objects must be deallocated as soon as native part does not need them anymore; * `EventEmitter` objects retain `EventTarget` objects; * `EventEmitter` can loose event target object in case if assosiated `ShadowNode` got unmounted (not deallocated); in this case `EventEmitter` is loosing possibility to dispatch event even if some mounting-layer code is still retaining it. Reviewed By: mdvacca Differential Revision: D9762755 fbshipit-source-id: 96e989767a32914db9f4627fce51b044c71f257a
55 lines
1.2 KiB
C++
55 lines
1.2 KiB
C++
/**
|
|
* 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 "EventQueue.h"
|
|
|
|
#include "EventEmitter.h"
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
EventQueue::EventQueue(EventPipe eventPipe, std::unique_ptr<EventBeat> eventBeat):
|
|
eventPipe_(std::move(eventPipe)),
|
|
eventBeat_(std::move(eventBeat)) {
|
|
eventBeat_->setBeatCallback(std::bind(&EventQueue::onBeat, this));
|
|
}
|
|
|
|
void EventQueue::enqueueEvent(const RawEvent &rawEvent) const {
|
|
std::lock_guard<std::mutex> lock(queueMutex_);
|
|
queue_.push_back(rawEvent);
|
|
}
|
|
|
|
void EventQueue::onBeat() const {
|
|
std::vector<RawEvent> queue;
|
|
|
|
{
|
|
std::lock_guard<std::mutex> lock(queueMutex_);
|
|
|
|
if (queue_.size() == 0) {
|
|
return;
|
|
}
|
|
|
|
queue = std::move(queue_);
|
|
assert(queue_.size() == 0);
|
|
}
|
|
|
|
{
|
|
std::lock_guard<std::recursive_mutex> lock(EventEmitter::DispatchMutex());
|
|
for (const auto &event : queue) {
|
|
auto eventTarget = event.eventTarget.lock();
|
|
eventPipe_(
|
|
eventTarget && event.isDispatchable() ? eventTarget.get() : nullptr,
|
|
event.type,
|
|
event.payload
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|