Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(773)

Side by Side Diff: android_webview/native/callback_jni_bridge.cc

Issue 12313042: [android_webview] Add a generic callback JNI bridge. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698