1*635a8641SAndroid Build Coastguard Worker // Copyright 2014 The Chromium Authors. All rights reserved. 2*635a8641SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*635a8641SAndroid Build Coastguard Worker // found in the LICENSE file. 4*635a8641SAndroid Build Coastguard Worker 5*635a8641SAndroid Build Coastguard Worker #ifndef BASE_ANDROID_JNI_WEAK_REF_H_ 6*635a8641SAndroid Build Coastguard Worker #define BASE_ANDROID_JNI_WEAK_REF_H_ 7*635a8641SAndroid Build Coastguard Worker 8*635a8641SAndroid Build Coastguard Worker #include <jni.h> 9*635a8641SAndroid Build Coastguard Worker 10*635a8641SAndroid Build Coastguard Worker #include "base/android/scoped_java_ref.h" 11*635a8641SAndroid Build Coastguard Worker #include "base/base_export.h" 12*635a8641SAndroid Build Coastguard Worker 13*635a8641SAndroid Build Coastguard Worker // Manages WeakGlobalRef lifecycle. 14*635a8641SAndroid Build Coastguard Worker // This class is not thread-safe w.r.t. get() and reset(). Multiple threads may 15*635a8641SAndroid Build Coastguard Worker // safely use get() concurrently, but if the user calls reset() (or of course, 16*635a8641SAndroid Build Coastguard Worker // calls the destructor) they'll need to provide their own synchronization. 17*635a8641SAndroid Build Coastguard Worker class BASE_EXPORT JavaObjectWeakGlobalRef { 18*635a8641SAndroid Build Coastguard Worker public: 19*635a8641SAndroid Build Coastguard Worker JavaObjectWeakGlobalRef(); 20*635a8641SAndroid Build Coastguard Worker JavaObjectWeakGlobalRef(const JavaObjectWeakGlobalRef& orig); 21*635a8641SAndroid Build Coastguard Worker JavaObjectWeakGlobalRef(JavaObjectWeakGlobalRef&& orig) noexcept; 22*635a8641SAndroid Build Coastguard Worker JavaObjectWeakGlobalRef(JNIEnv* env, jobject obj); 23*635a8641SAndroid Build Coastguard Worker JavaObjectWeakGlobalRef(JNIEnv* env, 24*635a8641SAndroid Build Coastguard Worker const base::android::JavaRef<jobject>& obj); 25*635a8641SAndroid Build Coastguard Worker virtual ~JavaObjectWeakGlobalRef(); 26*635a8641SAndroid Build Coastguard Worker 27*635a8641SAndroid Build Coastguard Worker void operator=(const JavaObjectWeakGlobalRef& rhs); 28*635a8641SAndroid Build Coastguard Worker void operator=(JavaObjectWeakGlobalRef&& rhs); 29*635a8641SAndroid Build Coastguard Worker 30*635a8641SAndroid Build Coastguard Worker base::android::ScopedJavaLocalRef<jobject> get(JNIEnv* env) const; 31*635a8641SAndroid Build Coastguard Worker 32*635a8641SAndroid Build Coastguard Worker // Returns true if the weak reference has not been initialized to point at 33*635a8641SAndroid Build Coastguard Worker // an object (or ḣas had reset() called). 34*635a8641SAndroid Build Coastguard Worker // Do not call this to test if the object referred to still exists! The weak 35*635a8641SAndroid Build Coastguard Worker // reference remains initialized even if the target object has been collected. is_uninitialized()36*635a8641SAndroid Build Coastguard Worker bool is_uninitialized() const { return obj_ == nullptr; } 37*635a8641SAndroid Build Coastguard Worker 38*635a8641SAndroid Build Coastguard Worker void reset(); 39*635a8641SAndroid Build Coastguard Worker 40*635a8641SAndroid Build Coastguard Worker private: 41*635a8641SAndroid Build Coastguard Worker void Assign(const JavaObjectWeakGlobalRef& rhs); 42*635a8641SAndroid Build Coastguard Worker 43*635a8641SAndroid Build Coastguard Worker jweak obj_; 44*635a8641SAndroid Build Coastguard Worker }; 45*635a8641SAndroid Build Coastguard Worker 46*635a8641SAndroid Build Coastguard Worker // Get the real object stored in the weak reference returned as a 47*635a8641SAndroid Build Coastguard Worker // ScopedJavaLocalRef. 48*635a8641SAndroid Build Coastguard Worker BASE_EXPORT base::android::ScopedJavaLocalRef<jobject> GetRealObject( 49*635a8641SAndroid Build Coastguard Worker JNIEnv* env, jweak obj); 50*635a8641SAndroid Build Coastguard Worker 51*635a8641SAndroid Build Coastguard Worker #endif // BASE_ANDROID_JNI_WEAK_REF_H_ 52