Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2013 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 #include "android_webview/native/callback_jni_bridge.h" | |
| 6 | |
| 7 #include "base/android/scoped_java_ref.h" | |
| 8 #include "base/bind.h" | |
| 9 #include "jni/CallbackJNIBridge_jni.h" | |
| 10 | |
| 11 using base::Callback; | |
| 12 using base::android::AttachCurrentThread; | |
| 13 using base::android::ScopedJavaLocalRef; | |
| 14 using base::android::ScopedJavaGlobalRef; | |
| 15 | |
| 16 namespace android_webview { | |
| 17 | |
| 18 class JavaValueCallbackInt { | |
| 19 public: | |
| 20 JavaValueCallbackInt(JNIEnv* env, | |
| 21 const ScopedJavaLocalRef<jobject>& jvalue_callback) { | |
| 22 jvalue_callback_.Reset(env, jvalue_callback.obj()); | |
| 23 } | |
| 24 | |
| 25 void onReceiveValue(int value) { | |
| 26 DCHECK(!jvalue_callback_.is_null()); | |
|
boliu
2013/02/21 23:11:12
Would be nice if it can automatically check thread
mkosiba (inactive)
2013/02/22 18:54:31
nope, the more auto-checking we have the better. I
| |
| 27 | |
| 28 if (!jvalue_callback_.is_null()) { | |
| 29 JNIEnv* env = AttachCurrentThread(); | |
| 30 Java_CallbackJNIBridge_invokeValueCallbackInt( | |
| 31 env, jvalue_callback_.obj(), value); | |
|
boliu
2013/02/22 23:02:52
Also just realized, generic types must be an objec
mkosiba (inactive)
2013/02/25 23:43:43
no, you'd have to new up an Integer object if you
| |
| 32 jvalue_callback_.Reset(); | |
| 33 } | |
| 34 } | |
| 35 | |
| 36 private: | |
| 37 ScopedJavaGlobalRef<jobject> jvalue_callback_; | |
| 38 }; | |
| 39 | |
| 40 Callback<void(int)> CallbackJNIBridge::FromJavaValueCallbackInt( | |
|
boliu
2013/02/21 23:11:12
There is no way to use templates to interpret the
mkosiba (inactive)
2013/02/22 18:54:31
I talked to Marcus and he'd prefer us to make the
boliu
2013/02/22 23:02:52
I'm gonna push back on this a bit at least for non
| |
| 41 JNIEnv* env, | |
| 42 ScopedJavaLocalRef<jobject> jvalue_callback) { | |
| 43 JavaValueCallbackInt* value_callback = | |
| 44 new JavaValueCallbackInt(env, jvalue_callback); | |
| 45 return base::Bind(&JavaValueCallbackInt::onReceiveValue, | |
| 46 base::Owned(value_callback)); | |
| 47 } | |
| 48 | |
| 49 ScopedJavaLocalRef<jobject> CallbackJNIBridge::ToJavaValueCallbackInt( | |
| 50 JNIEnv* env, | |
| 51 const Callback<void(int)>& callback) { | |
| 52 Callback<void(int)>* native_callback = new Callback<void(int)>(callback); | |
|
boliu
2013/02/21 23:11:12
new vs copy by value, the native object only holds
mkosiba (inactive)
2013/02/22 18:54:31
The Callback has an internal scoped_refptr<BindSta
| |
| 53 ScopedJavaLocalRef<jobject> jvalue_callback = | |
| 54 Java_CallbackJNIBridge_createValueCallbackInt( | |
| 55 env, reinterpret_cast<int>(native_callback)); | |
| 56 | |
| 57 return jvalue_callback; | |
| 58 } | |
| 59 | |
| 60 // static methods ------------------------------------------------------------- | |
| 61 | |
| 62 static void OnReceiveValueInt(JNIEnv* env, | |
| 63 jclass clazz, | |
| 64 jint callbackInt, | |
| 65 jint value) { | |
| 66 Callback<void(int)>* native_callback = | |
| 67 reinterpret_cast<Callback<void(int)>*>(callbackInt); | |
| 68 native_callback->Run(value); | |
| 69 } | |
| 70 | |
| 71 static void DestroyInt(JNIEnv* env, jclass clazz, jint callbackInt) { | |
| 72 Callback<void(int)>* native_callback = | |
| 73 reinterpret_cast<Callback<void(int)>*>(callbackInt); | |
| 74 delete native_callback; | |
| 75 } | |
| 76 | |
| 77 bool RegisterCallbackJNIBridge(JNIEnv* env) { | |
| 78 return RegisterNativesImpl(env); | |
| 79 } | |
| 80 | |
| 81 } // namespace android_webview | |
| OLD | NEW |