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

Side by Side Diff: base/android/jni_android.h

Issue 9358028: Upstream Android JNI code, allowing us to use more ScopedJava references. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased and added a TODO Created 8 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
« no previous file with comments | « no previous file | base/android/jni_android.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_ANDROID_H_ 5 #ifndef BASE_ANDROID_JNI_ANDROID_H_
6 #define BASE_ANDROID_JNI_ANDROID_H_ 6 #define BASE_ANDROID_JNI_ANDROID_H_
7 7
8 #include <jni.h> 8 #include <jni.h>
9 #include <sys/types.h> 9 #include <sys/types.h>
10 10
11 #include "base/android/scoped_java_ref.h" 11 #include "base/android/scoped_java_ref.h"
12 12
13 namespace base { 13 namespace base {
14 namespace android { 14 namespace android {
15 15
16 // Attach the current thread to the VM (if necessary) and return the JNIEnv*. 16 // Attach the current thread to the VM (if necessary) and return the JNIEnv*.
17 JNIEnv* AttachCurrentThread(); 17 JNIEnv* AttachCurrentThread();
18 18
19 // Detach the current thread from VM if it is attached. 19 // Detach the current thread from VM if it is attached.
20 void DetachFromVM(); 20 void DetachFromVM();
21 21
22 // Initializes the global JVM. It is not necessarily called before 22 // Initializes the global JVM. It is not necessarily called before
23 // InitApplicationContext(). 23 // InitApplicationContext().
24 void InitVM(JavaVM* vm); 24 void InitVM(JavaVM* vm);
25 25
26 // Initializes the global application context object. The |context| can be any 26 // Initializes the global application context object. The |context| can be any
27 // valid reference to the application context. Internally holds a global ref to 27 // valid reference to the application context. Internally holds a global ref to
28 // the context. InitVM and InitApplicationContext maybe called in either order. 28 // the context. InitVM and InitApplicationContext maybe called in either order.
29 // TODO: We might combine InitVM() and InitApplicationContext() into one method.
30 void InitApplicationContext(const JavaRef<jobject>& context); 29 void InitApplicationContext(const JavaRef<jobject>& context);
31 30
32 // Gets a global ref to the application context set with 31 // Gets a global ref to the application context set with
33 // InitApplicationContext(). Ownership is retained by the function - the caller 32 // InitApplicationContext(). Ownership is retained by the function - the caller
34 // must NOT release it. 33 // must NOT release it.
35 jobject GetApplicationContext(); 34 const jobject GetApplicationContext();
35
36 // Finds the class named |class_name| and returns it.
37 // Use this method instead of invoking directly the JNI FindClass method (to
38 // prevent leaking local references).
39 // This method triggers a fatal assertion if the class could not be found.
40 // Use HasClass if you need to check whether the class exists.
41 ScopedJavaLocalRef<jclass> GetClass(JNIEnv* env, const char* class_name);
42
43 // Returns true iff the class |class_name| could be found.
44 bool HasClass(JNIEnv* env, const char* class_name);
45
46 // Returns the method ID for the method with the specified name and signature.
47 // This method triggers a fatal assertion if the method could not be found.
48 // Use HasMethod if you need to check whether a method exists.
49 jmethodID GetMethodID(JNIEnv* env,
50 const JavaRef<jclass>& clazz,
51 const char* method_name,
52 const char* jni_signature);
53
54 // Returns the method ID for the static method with the specified name and
55 // signature.
56 // This method triggers a fatal assertion if the method could not be found.
57 // Use HasMethod if you need to check whether a method exists.
58 jmethodID GetStaticMethodID(JNIEnv* env,
59 const JavaRef<jclass>& clazz,
60 const char* method_name,
61 const char* jni_signature);
62
63 // Returns true iff |clazz| has a method with the specified name and signature.
64 bool HasMethod(JNIEnv* env,
65 const JavaRef<jclass>& clazz,
66 const char* method_name,
67 const char* jni_signature);
36 68
37 // Gets the method ID from the class name. Clears the pending Java exception 69 // Gets the method ID from the class name. Clears the pending Java exception
38 // and returns NULL if the method is not found. Caches results. Note that 70 // and returns NULL if the method is not found. Caches results. Note that
39 // GetMethodID() below avoids a class lookup, but does not cache results. 71 // GetMethodID() below avoids a class lookup, but does not cache results.
40 // Strings passed to this function are held in the cache and MUST remain valid 72 // Strings passed to this function are held in the cache and MUST remain valid
41 // beyond the duration of all future calls to this function, across all 73 // beyond the duration of all future calls to this function, across all
42 // threads. In practice, this means that the function should only be used with 74 // threads. In practice, this means that the function should only be used with
43 // string constants. 75 // string constants.
44 jmethodID GetMethodIDFromClassName(JNIEnv* env, 76 jmethodID GetMethodIDFromClassName(JNIEnv* env,
45 const char* class_name, 77 const char* class_name,
46 const char* method, 78 const char* method,
47 const char* jni_signature); 79 const char* jni_signature);
48 80
49 // Get the method ID for a method. Will clear the pending Java 81 // Gets the field ID for a class field.
50 // exception and return 0 if the method is not found. 82 // This method triggers a fatal assertion if the field could not be found.
51 jmethodID GetMethodID(JNIEnv* env,
52 jclass clazz,
53 const char* const method,
54 const char* const jni_signature);
55
56 // Get the method ID for a class static method. Will clear the pending Java
57 // exception and return 0 if the method is not found.
58 jmethodID GetStaticMethodID(JNIEnv* env,
59 jclass clazz,
60 const char* const method,
61 const char* const jni_signature);
62
63 // Gets the field ID for a class field. Clears the pending Java exception and
64 // returns NULL if the field is not found.
65 jfieldID GetFieldID(JNIEnv* env, 83 jfieldID GetFieldID(JNIEnv* env,
66 jclass clazz, 84 const JavaRef<jclass>& clazz,
67 const char* field, 85 const char* field_name,
68 const char* jni_signature); 86 const char* jni_signature);
69 87
70 // Returns true if an exception is pending in the provided JNIEnv*. If an 88 // Returns true if |clazz| as a field with the given name and signature.
71 // exception is pending, this function prints and then clears it. 89 // TODO(jcivelli): Determine whether we explicitly have to pass the environment.
72 bool CheckException(JNIEnv* env); 90 bool HasField(JNIEnv* env,
91 const JavaRef<jclass>& clazz,
92 const char* field_name,
93 const char* jni_signature);
94
95 // Gets the field ID for a static class field.
96 // This method triggers a fatal assertion if the field could not be found.
97 jfieldID GetStaticFieldID(JNIEnv* env,
98 const JavaRef<jclass>& clazz,
99 const char* field_name,
100 const char* jni_signature);
101
102 // Returns true if an exception is pending in the provided JNIEnv*.
103 bool HasException(JNIEnv* env);
104
105 // If an exception is pending in the provided JNIEnv*, this function clears it
106 // and returns true.
107 bool ClearException(JNIEnv* env);
108
109 // This function will call CHECK() macro if there's any pending exception.
110 void CheckException(JNIEnv* env);
73 111
74 } // namespace android 112 } // namespace android
75 } // namespace base 113 } // namespace base
76 114
77 #endif // BASE_ANDROID_JNI_ANDROID_H_ 115 #endif // BASE_ANDROID_JNI_ANDROID_H_
OLDNEW
« no previous file with comments | « no previous file | base/android/jni_android.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698