xref: /aosp_15_r20/external/libchrome/base/android/jni_weak_ref.h (revision 635a864187cb8b6c713ff48b7e790a6b21769273)
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