blob: 43a26b5fe5732cfdebc0a8890faf2c807779060c [file] [log] [blame]
newt@chromium.org9910bed2014-04-24 05:01:20 +09001// Copyright 2014 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef BASE_ANDROID_JNI_WEAK_REF_H_
6#define BASE_ANDROID_JNI_WEAK_REF_H_
7
8#include <jni.h>
9
10#include "base/android/scoped_java_ref.h"
11#include "base/base_export.h"
12
13// Manages WeakGlobalRef lifecycle.
14// This class is not thread-safe w.r.t. get() and reset(). Multiple threads may
15// safely use get() concurrently, but if the user calls reset() (or of course,
16// calls the destructor) they'll need to provide their own synchronization.
17class BASE_EXPORT JavaObjectWeakGlobalRef {
18 public:
19 JavaObjectWeakGlobalRef();
20 JavaObjectWeakGlobalRef(const JavaObjectWeakGlobalRef& orig);
brettwce38c192017-03-25 01:36:42 +090021 JavaObjectWeakGlobalRef(JavaObjectWeakGlobalRef&& orig) noexcept;
newt@chromium.org9910bed2014-04-24 05:01:20 +090022 JavaObjectWeakGlobalRef(JNIEnv* env, jobject obj);
torne1cec5af2016-08-26 00:42:57 +090023 JavaObjectWeakGlobalRef(JNIEnv* env,
24 const base::android::JavaRef<jobject>& obj);
newt@chromium.org9910bed2014-04-24 05:01:20 +090025 virtual ~JavaObjectWeakGlobalRef();
26
27 void operator=(const JavaObjectWeakGlobalRef& rhs);
torne1cec5af2016-08-26 00:42:57 +090028 void operator=(JavaObjectWeakGlobalRef&& rhs);
newt@chromium.org9910bed2014-04-24 05:01:20 +090029
30 base::android::ScopedJavaLocalRef<jobject> get(JNIEnv* env) const;
31
torne83c56382016-11-08 08:30:49 +090032 // Returns true if the weak reference has not been initialized to point at
33 // an object (or ḣas had reset() called).
34 // Do not call this to test if the object referred to still exists! The weak
35 // reference remains initialized even if the target object has been collected.
36 bool is_uninitialized() const { return obj_ == nullptr; }
mnaganov@chromium.orga3997162014-06-12 17:36:08 +090037
newt@chromium.org9910bed2014-04-24 05:01:20 +090038 void reset();
39
40 private:
41 void Assign(const JavaObjectWeakGlobalRef& rhs);
42
43 jweak obj_;
44};
45
46// Get the real object stored in the weak reference returned as a
47// ScopedJavaLocalRef.
48BASE_EXPORT base::android::ScopedJavaLocalRef<jobject> GetRealObject(
49 JNIEnv* env, jweak obj);
50
51#endif // BASE_ANDROID_JNI_WEAK_REF_H_