// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_ANDROID_JNI_WEAK_REF_H_ #define BASE_ANDROID_JNI_WEAK_REF_H_ #include <jni.h> #include "base/android/scoped_java_ref.h" #include "base/base_export.h" // Manages WeakGlobalRef lifecycle. // This class is not thread-safe w.r.t. get() and reset(). Multiple threads may // safely use get() concurrently, but if the user calls reset() (or of course, // calls the destructor) they'll need to provide their own synchronization. class BASE_EXPORT JavaObjectWeakGlobalRef { public: JavaObjectWeakGlobalRef(); JavaObjectWeakGlobalRef(const JavaObjectWeakGlobalRef& orig); JavaObjectWeakGlobalRef(JNIEnv* env, jobject obj); virtual ~JavaObjectWeakGlobalRef(); void operator=(const JavaObjectWeakGlobalRef& rhs); base::android::ScopedJavaLocalRef<jobject> get(JNIEnv* env) const; bool is_empty() const { return obj_ == NULL; } void reset(); private: void Assign(const JavaObjectWeakGlobalRef& rhs); jweak obj_; }; // Get the real object stored in the weak reference returned as a // ScopedJavaLocalRef. BASE_EXPORT base::android::ScopedJavaLocalRef<jobject> GetRealObject( JNIEnv* env, jweak obj); #endif // BASE_ANDROID_JNI_WEAK_REF_H_