diff --git a/package/android/src/main/cpp/MutableJByteBuffer.cpp b/package/android/src/main/cpp/MutableJByteBuffer.cpp index 080f8a5602..b4d5695853 100644 --- a/package/android/src/main/cpp/MutableJByteBuffer.cpp +++ b/package/android/src/main/cpp/MutableJByteBuffer.cpp @@ -15,6 +15,9 @@ MutableJByteBuffer::MutableJByteBuffer(jni::alias_ref byteBuff } MutableJByteBuffer::~MutableJByteBuffer() noexcept { + // Hermes GC might destroy HostObjects on an arbitrary Thread which might not be + // connected to the JNI environment. To make sure fbjni can properly destroy + // the Java method, we connect to a JNI environment first. jni::ThreadScope::WithClassLoader([&] { _byteBuffer.reset(); }); } @@ -30,4 +33,4 @@ jni::global_ref MutableJByteBuffer::getByteBuffer() { return _byteBuffer; } -} // namespace vision \ No newline at end of file +} // namespace vision diff --git a/package/android/src/main/cpp/frameprocessor/FrameHostObject.cpp b/package/android/src/main/cpp/frameprocessor/FrameHostObject.cpp index 27265fde9b..773cde6de9 100644 --- a/package/android/src/main/cpp/frameprocessor/FrameHostObject.cpp +++ b/package/android/src/main/cpp/frameprocessor/FrameHostObject.cpp @@ -22,10 +22,9 @@ using namespace facebook; FrameHostObject::FrameHostObject(const jni::alias_ref& frame) : frame(make_global(frame)) {} FrameHostObject::~FrameHostObject() { - // Hermes' Garbage Collector (Hades GC) calls destructors on a separate Thread - // which might not be attached to JNI. Ensure that we use the JNI class loader when - // deallocating the `frame` HybridClass, because otherwise JNI cannot call the Java - // destroy() function. + // Hermes GC might destroy HostObjects on an arbitrary Thread which might not be + // connected to the JNI environment. To make sure fbjni can properly destroy + // the Java method, we connect to a JNI environment first. jni::ThreadScope::WithClassLoader([&] { frame.reset(); }); } diff --git a/package/android/src/main/cpp/frameprocessor/FrameProcessorPluginHostObject.cpp b/package/android/src/main/cpp/frameprocessor/FrameProcessorPluginHostObject.cpp index ecd5983457..075232ab3f 100644 --- a/package/android/src/main/cpp/frameprocessor/FrameProcessorPluginHostObject.cpp +++ b/package/android/src/main/cpp/frameprocessor/FrameProcessorPluginHostObject.cpp @@ -16,6 +16,9 @@ FrameProcessorPluginHostObject::FrameProcessorPluginHostObject(jni::alias_ref VisionCameraProxy::getPropertyNames(jsi::Runtime& runtime) { std::vector result; @@ -96,6 +101,10 @@ jsi::Value VisionCameraProxy::get(jsi::Runtime& runtime, const jsi::PropNameID& return jsi::Value::undefined(); } +void VisionCameraInstaller::registerNatives() { + javaClassStatic()->registerNatives({makeNativeMethod("install", VisionCameraInstaller::install)}); +} + void VisionCameraInstaller::install(jni::alias_ref, jni::alias_ref proxy) { // global.VisionCameraProxy auto visionCameraProxy = std::make_shared(proxy); diff --git a/package/android/src/main/cpp/frameprocessor/VisionCameraProxy.h b/package/android/src/main/cpp/frameprocessor/VisionCameraProxy.h index ab086f75f8..fe18c53ca9 100644 --- a/package/android/src/main/cpp/frameprocessor/VisionCameraProxy.h +++ b/package/android/src/main/cpp/frameprocessor/VisionCameraProxy.h @@ -38,9 +38,7 @@ class VisionCameraProxy : public jsi::HostObject { class VisionCameraInstaller : public jni::JavaClass { public: static auto constexpr kJavaDescriptor = "Lcom/mrousavy/camera/frameprocessor/VisionCameraInstaller;"; - static void registerNatives() { - javaClassStatic()->registerNatives({makeNativeMethod("install", VisionCameraInstaller::install)}); - } + static void registerNatives(); static void install(jni::alias_ref clazz, jni::alias_ref proxy); };