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 |