Files
react-native/ReactCommon/react/bridging/LongLivedObject.cpp
T
Pieter De Baets c28c6f2531 JavaTurboModule/LongLivedObject cleanup (#36367)
Summary:
Pull Request resolved: https://github.com/facebook/react-native/pull/36367

* Don't iterate over JSI Value to get args, convert each of the args individually instead
* Make LongLivedObjectCollection constructor private
* allowRelease does not need to be virtual
* Move away from const-ness as a thread-safety indicator

Changelog: [Internal]

Reviewed By: christophpurrer

Differential Revision: D43354535

fbshipit-source-id: eaf8eb931ab6ec307a3dc2690eabeb34bb6afa77
2023-03-07 01:17:44 -08:00

52 lines
1.2 KiB
C++

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#include "LongLivedObject.h"
namespace facebook {
namespace react {
// LongLivedObjectCollection
LongLivedObjectCollection &LongLivedObjectCollection::get() {
static LongLivedObjectCollection instance;
return instance;
}
void LongLivedObjectCollection::add(std::shared_ptr<LongLivedObject> so) {
std::lock_guard<std::mutex> lock(collectionMutex_);
collection_.insert(std::move(so));
}
void LongLivedObjectCollection::remove(const LongLivedObject *o) {
std::lock_guard<std::mutex> lock(collectionMutex_);
for (auto p = collection_.begin(); p != collection_.end(); p++) {
if (p->get() == o) {
collection_.erase(p);
break;
}
}
}
void LongLivedObjectCollection::clear() {
std::lock_guard<std::mutex> lock(collectionMutex_);
collection_.clear();
}
size_t LongLivedObjectCollection::size() const {
std::lock_guard<std::mutex> lock(collectionMutex_);
return collection_.size();
}
// LongLivedObject
void LongLivedObject::allowRelease() {
LongLivedObjectCollection::get().remove(this);
}
} // namespace react
} // namespace facebook