Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef BASE_ANDROID_JNI_WEAK_REF_H_ | 5 #ifndef BASE_ANDROID_JNI_WEAK_REF_H_ |
| 6 #define BASE_ANDROID_JNI_WEAK_REF_H_ | 6 #define BASE_ANDROID_JNI_WEAK_REF_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 | 9 |
| 10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
| 11 #include "base/base_export.h" | 11 #include "base/base_export.h" |
| 12 | 12 |
| 13 // Manages WeakGlobalRef lifecycle. | 13 // Manages WeakGlobalRef lifecycle. |
| 14 // This class is not thread-safe w.r.t. get() and reset(). Multiple threads may | 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, | 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. | 16 // calls the destructor) they'll need to provide their own synchronization. |
| 17 class BASE_EXPORT JavaObjectWeakGlobalRef { | 17 class BASE_EXPORT JavaObjectWeakGlobalRef { |
| 18 public: | 18 public: |
| 19 JavaObjectWeakGlobalRef(); | 19 JavaObjectWeakGlobalRef(); |
| 20 JavaObjectWeakGlobalRef(const JavaObjectWeakGlobalRef& orig); | 20 JavaObjectWeakGlobalRef(const JavaObjectWeakGlobalRef& orig); |
| 21 JavaObjectWeakGlobalRef(JNIEnv* env, jobject obj); | 21 JavaObjectWeakGlobalRef(JNIEnv* env, jobject obj); |
| 22 virtual ~JavaObjectWeakGlobalRef(); | 22 virtual ~JavaObjectWeakGlobalRef(); |
| 23 | 23 |
| 24 void operator=(const JavaObjectWeakGlobalRef& rhs); | 24 void operator=(const JavaObjectWeakGlobalRef& rhs); |
| 25 | 25 |
| 26 base::android::ScopedJavaLocalRef<jobject> get(JNIEnv* env) const; | 26 base::android::ScopedJavaLocalRef<jobject> get(JNIEnv* env) const; |
| 27 | 27 |
| 28 bool is_null() const { return obj_ == NULL; } | |
|
bulach
2014/06/09 11:44:33
hmm... :)
this can be misleading, it'd be possibl
mnaganov (inactive)
2014/06/11 13:50:44
Thanks for raising this! Indeed, is_null() seems t
| |
| 29 | |
| 28 void reset(); | 30 void reset(); |
| 29 | 31 |
| 30 private: | 32 private: |
| 31 void Assign(const JavaObjectWeakGlobalRef& rhs); | 33 void Assign(const JavaObjectWeakGlobalRef& rhs); |
| 32 | 34 |
| 33 jweak obj_; | 35 jweak obj_; |
| 34 }; | 36 }; |
| 35 | 37 |
| 36 // Get the real object stored in the weak reference returned as a | 38 // Get the real object stored in the weak reference returned as a |
| 37 // ScopedJavaLocalRef. | 39 // ScopedJavaLocalRef. |
| 38 BASE_EXPORT base::android::ScopedJavaLocalRef<jobject> GetRealObject( | 40 BASE_EXPORT base::android::ScopedJavaLocalRef<jobject> GetRealObject( |
| 39 JNIEnv* env, jweak obj); | 41 JNIEnv* env, jweak obj); |
| 40 | 42 |
| 41 #endif // BASE_ANDROID_JNI_WEAK_REF_H_ | 43 #endif // BASE_ANDROID_JNI_WEAK_REF_H_ |
| OLD | NEW |