xref: /aosp_15_r20/external/cronet/base/android/jni_array.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1 // Copyright 2012 The Chromium Authors
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef BASE_ANDROID_JNI_ARRAY_H_
6 #define BASE_ANDROID_JNI_ARRAY_H_
7 
8 #include <jni.h>
9 #include <stddef.h>
10 #include <stdint.h>
11 #include <ostream>
12 #include <string>
13 #include <vector>
14 
15 #include "base/android/scoped_java_ref.h"
16 #include "base/check_op.h"
17 #include "base/containers/span.h"
18 
19 namespace base::android {
20 
21 // As |GetArrayLength| makes no guarantees about the returned value (e.g., it
22 // may be -1 if |array| is not a valid Java array), provide a safe wrapper
23 // that always returns a valid, non-negative size.
24 // Returns the length of Java array.
25 template <typename JavaArrayType>
SafeGetArrayLength(JNIEnv * env,const JavaRef<JavaArrayType> & jarray)26 BASE_EXPORT size_t SafeGetArrayLength(JNIEnv* env,
27                                       const JavaRef<JavaArrayType>& jarray) {
28   DCHECK(jarray);
29   jsize length = env->GetArrayLength(jarray.obj());
30   DCHECK_GE(length, 0) << "Invalid array length: " << length;
31   return static_cast<size_t>(std::max(0, length));
32 }
33 
34 // Returns a new Java byte array converted from the given bytes array.
35 BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray(JNIEnv* env,
36                                                            const uint8_t* bytes,
37                                                            size_t len);
38 
39 BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray(
40     JNIEnv* env,
41     base::span<const uint8_t> bytes);
42 
43 // Returns a new Java byte array converted from the given string. No UTF-8
44 // conversion is performed.
45 BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray(
46     JNIEnv* env,
47     const std::string& str);
48 
49 // Returns a new Java boolean array converted from the given bool array.
50 BASE_EXPORT ScopedJavaLocalRef<jbooleanArray>
51 ToJavaBooleanArray(JNIEnv* env, const bool* bools, size_t len);
52 
53 // Returns a new Java int array converted from the given int array.
54 BASE_EXPORT ScopedJavaLocalRef<jintArray> ToJavaIntArray(
55     JNIEnv* env, const int* ints, size_t len);
56 
57 BASE_EXPORT ScopedJavaLocalRef<jintArray> ToJavaIntArray(
58     JNIEnv* env,
59     base::span<const int> ints);
60 
61 // Returns a new Java long array converted from the given int64_t array.
62 BASE_EXPORT ScopedJavaLocalRef<jlongArray> ToJavaLongArray(JNIEnv* env,
63                                                            const int64_t* longs,
64                                                            size_t len);
65 
66 BASE_EXPORT ScopedJavaLocalRef<jlongArray> ToJavaLongArray(
67     JNIEnv* env,
68     base::span<const int64_t> longs);
69 
70 // Returns a new Java float array converted from the given C++ float array.
71 BASE_EXPORT ScopedJavaLocalRef<jfloatArray> ToJavaFloatArray(
72     JNIEnv* env, const float* floats, size_t len);
73 
74 BASE_EXPORT ScopedJavaLocalRef<jfloatArray> ToJavaFloatArray(
75     JNIEnv* env,
76     base::span<const float> floats);
77 
78 // Returns a new Java double array converted from the given C++ double array.
79 BASE_EXPORT ScopedJavaLocalRef<jdoubleArray>
80 ToJavaDoubleArray(JNIEnv* env, const double* doubles, size_t len);
81 
82 BASE_EXPORT ScopedJavaLocalRef<jdoubleArray> ToJavaDoubleArray(
83     JNIEnv* env,
84     base::span<const double> doubles);
85 
86 // Returns a new clazz[] with the content of |v|.
87 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects(
88     JNIEnv* env,
89     jclass clazz,
90     base::span<const ScopedJavaLocalRef<jobject>> v);
91 
92 // Returns a new Object[] with the content of |v|.
93 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects(
94     JNIEnv* env,
95     base::span<const ScopedJavaLocalRef<jobject>> v);
96 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects(
97     JNIEnv* env,
98     base::span<const ScopedJavaGlobalRef<jobject>> v);
99 
100 // Returns a new Type[] with the content of |v|.
101 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToTypedJavaArrayOfObjects(
102     JNIEnv* env,
103     base::span<const ScopedJavaLocalRef<jobject>> v,
104     jclass type);
105 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToTypedJavaArrayOfObjects(
106     JNIEnv* env,
107     base::span<const ScopedJavaGlobalRef<jobject>> v,
108     jclass type);
109 
110 // Returns a array of Java byte array converted from |v|.
111 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfByteArray(
112     JNIEnv* env,
113     base::span<const std::string> v);
114 
115 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfByteArray(
116     JNIEnv* env,
117     base::span<const std::vector<uint8_t>> v);
118 
119 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStrings(
120     JNIEnv* env,
121     base::span<const std::string> v);
122 
123 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStrings(
124     JNIEnv* env,
125     base::span<const std::u16string> v);
126 
127 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStringArray(
128     JNIEnv* env,
129     base::span<const std::vector<std::string>> v);
130 
131 BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStringArray(
132     JNIEnv* env,
133     base::span<const std::vector<std::u16string>> v);
134 
135 // Converts a Java string array to a native array.
136 BASE_EXPORT void AppendJavaStringArrayToStringVector(
137     JNIEnv* env,
138     const JavaRef<jobjectArray>& array,
139     std::vector<std::u16string>* out);
140 
141 BASE_EXPORT void AppendJavaStringArrayToStringVector(
142     JNIEnv* env,
143     const JavaRef<jobjectArray>& array,
144     std::vector<std::string>* out);
145 
146 // Appends the Java bytes in |bytes_array| onto the end of |out|.
147 BASE_EXPORT void AppendJavaByteArrayToByteVector(
148     JNIEnv* env,
149     const JavaRef<jbyteArray>& byte_array,
150     std::vector<uint8_t>* out);
151 
152 // Replaces the content of |out| with the Java bytes in |byte_array|.
153 BASE_EXPORT void JavaByteArrayToByteVector(
154     JNIEnv* env,
155     const JavaRef<jbyteArray>& byte_array,
156     std::vector<uint8_t>* out);
157 
158 // Copy the contents of java |byte_array| into |dest|. The span must be larger
159 // than or equal to the array.
160 // Returns the number of bytes copied.
161 BASE_EXPORT size_t
162 JavaByteArrayToByteSpan(JNIEnv* env,
163                         const JavaRef<jbyteArray>& byte_array,
164                         base::span<uint8_t> dest);
165 
166 // Replaces the content of |out| with the Java bytes in |byte_array|. No UTF-8
167 // conversion is performed.
168 BASE_EXPORT void JavaByteArrayToString(JNIEnv* env,
169                                        const JavaRef<jbyteArray>& byte_array,
170                                        std::string* out);
171 
172 // Replaces the content of |out| with the Java booleans in |boolean_array|.
173 BASE_EXPORT void JavaBooleanArrayToBoolVector(
174     JNIEnv* env,
175     const JavaRef<jbooleanArray>& boolean_array,
176     std::vector<bool>* out);
177 
178 // Replaces the content of |out| with the Java ints in |int_array|.
179 BASE_EXPORT void JavaIntArrayToIntVector(JNIEnv* env,
180                                          const JavaRef<jintArray>& int_array,
181                                          std::vector<int>* out);
182 
183 // Replaces the content of |out| with the Java longs in |long_array|.
184 BASE_EXPORT void JavaLongArrayToInt64Vector(
185     JNIEnv* env,
186     const JavaRef<jlongArray>& long_array,
187     std::vector<int64_t>* out);
188 
189 // Replaces the content of |out| with the Java longs in |long_array|.
190 BASE_EXPORT void JavaLongArrayToLongVector(
191     JNIEnv* env,
192     const JavaRef<jlongArray>& long_array,
193     std::vector<jlong>* out);
194 
195 // Replaces the content of |out| with the Java floats in |float_array|.
196 BASE_EXPORT void JavaFloatArrayToFloatVector(
197     JNIEnv* env,
198     const JavaRef<jfloatArray>& float_array,
199     std::vector<float>* out);
200 
201 // Replaces the content of |out| with the Java doubles in |double_array|.
202 BASE_EXPORT void JavaDoubleArrayToDoubleVector(
203     JNIEnv* env,
204     const JavaRef<jdoubleArray>& double_array,
205     std::vector<double>* out);
206 
207 // Assuming |array| is an byte[][] (array of byte arrays), replaces the
208 // content of |out| with the corresponding vector of strings. No UTF-8
209 // conversion is performed.
210 BASE_EXPORT void JavaArrayOfByteArrayToStringVector(
211     JNIEnv* env,
212     const JavaRef<jobjectArray>& array,
213     std::vector<std::string>* out);
214 
215 // Assuming |array| is an byte[][] (array of byte arrays), replaces the
216 // content of |out| with the corresponding vector of vector of uint8. No UTF-8
217 // conversion is performed.
218 BASE_EXPORT void JavaArrayOfByteArrayToBytesVector(
219     JNIEnv* env,
220     const JavaRef<jobjectArray>& array,
221     std::vector<std::vector<uint8_t>>* out);
222 
223 // Assuming |array| is an String[][] (array of String arrays), replaces the
224 // content of |out| with the corresponding vector of string vectors.
225 BASE_EXPORT void Java2dStringArrayTo2dStringVector(
226     JNIEnv* env,
227     const JavaRef<jobjectArray>& array,
228     std::vector<std::vector<std::string>>* out);
229 
230 // Assuming |array| is an String[][] (array of String arrays), replaces the
231 // content of |out| with the corresponding vector of string vectors. No UTF-8
232 // conversion is performed.
233 BASE_EXPORT void Java2dStringArrayTo2dStringVector(
234     JNIEnv* env,
235     const JavaRef<jobjectArray>& array,
236     std::vector<std::vector<std::u16string>>* out);
237 
238 // Assuming |array| is an int[][] (array of int arrays), replaces the
239 // contents of |out| with the corresponding vectors of ints.
240 BASE_EXPORT void JavaArrayOfIntArrayToIntVector(
241     JNIEnv* env,
242     const JavaRef<jobjectArray>& array,
243     std::vector<std::vector<int>>* out);
244 
245 }  // namespace base::android
246 
247 #endif  // BASE_ANDROID_JNI_ARRAY_H_
248