| // Copyright 2012 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef BASE_ANDROID_JNI_ARRAY_H_ |
| #define BASE_ANDROID_JNI_ARRAY_H_ |
| |
| #include <jni.h> |
| #include <stddef.h> |
| #include <stdint.h> |
| #include <ostream> |
| #include <string> |
| #include <vector> |
| |
| #include "base/android/scoped_java_ref.h" |
| #include "base/check_op.h" |
| #include "base/containers/span.h" |
| |
| namespace base::android { |
| |
| // As |GetArrayLength| makes no guarantees about the returned value (e.g., it |
| // may be -1 if |array| is not a valid Java array), provide a safe wrapper |
| // that always returns a valid, non-negative size. |
| // Returns the length of Java array. |
| template <typename JavaArrayType> |
| BASE_EXPORT size_t SafeGetArrayLength(JNIEnv* env, |
| const JavaRef<JavaArrayType>& jarray) { |
| DCHECK(jarray); |
| jsize length = env->GetArrayLength(jarray.obj()); |
| DCHECK_GE(length, 0) << "Invalid array length: " << length; |
| return static_cast<size_t>(std::max(0, length)); |
| } |
| |
| // Returns a new Java byte array converted from the given bytes array. |
| BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray(JNIEnv* env, |
| const uint8_t* bytes, |
| size_t len); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray( |
| JNIEnv* env, |
| base::span<const uint8_t> bytes); |
| |
| // Returns a new Java byte array converted from the given string. No UTF-8 |
| // conversion is performed. |
| BASE_EXPORT ScopedJavaLocalRef<jbyteArray> ToJavaByteArray( |
| JNIEnv* env, |
| const std::string& str); |
| |
| // Returns a new Java boolean array converted from the given bool array. |
| BASE_EXPORT ScopedJavaLocalRef<jbooleanArray> |
| ToJavaBooleanArray(JNIEnv* env, const bool* bools, size_t len); |
| |
| // Returns a new Java int array converted from the given int array. |
| BASE_EXPORT ScopedJavaLocalRef<jintArray> ToJavaIntArray( |
| JNIEnv* env, const int* ints, size_t len); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jintArray> ToJavaIntArray( |
| JNIEnv* env, |
| base::span<const int> ints); |
| |
| // Returns a new Java long array converted from the given int64_t array. |
| BASE_EXPORT ScopedJavaLocalRef<jlongArray> ToJavaLongArray(JNIEnv* env, |
| const int64_t* longs, |
| size_t len); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jlongArray> ToJavaLongArray( |
| JNIEnv* env, |
| base::span<const int64_t> longs); |
| |
| // Returns a new Java float array converted from the given C++ float array. |
| BASE_EXPORT ScopedJavaLocalRef<jfloatArray> ToJavaFloatArray( |
| JNIEnv* env, const float* floats, size_t len); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jfloatArray> ToJavaFloatArray( |
| JNIEnv* env, |
| base::span<const float> floats); |
| |
| // Returns a new Java double array converted from the given C++ double array. |
| BASE_EXPORT ScopedJavaLocalRef<jdoubleArray> |
| ToJavaDoubleArray(JNIEnv* env, const double* doubles, size_t len); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jdoubleArray> ToJavaDoubleArray( |
| JNIEnv* env, |
| base::span<const double> doubles); |
| |
| // Returns a new clazz[] with the content of |v|. |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects( |
| JNIEnv* env, |
| ScopedJavaLocalRef<jclass> clazz, |
| base::span<const ScopedJavaLocalRef<jobject>> v); |
| |
| // Returns a new Object[] with the content of |v|. |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects( |
| JNIEnv* env, |
| base::span<const ScopedJavaLocalRef<jobject>> v); |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfObjects( |
| JNIEnv* env, |
| base::span<const ScopedJavaGlobalRef<jobject>> v); |
| |
| // Returns a new Type[] with the content of |v|. |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToTypedJavaArrayOfObjects( |
| JNIEnv* env, |
| base::span<const ScopedJavaLocalRef<jobject>> v, |
| ScopedJavaLocalRef<jclass> type); |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToTypedJavaArrayOfObjects( |
| JNIEnv* env, |
| base::span<const ScopedJavaGlobalRef<jobject>> v, |
| ScopedJavaLocalRef<jclass> type); |
| |
| // Returns a array of Java byte array converted from |v|. |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfByteArray( |
| JNIEnv* env, |
| base::span<const std::string> v); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfByteArray( |
| JNIEnv* env, |
| base::span<const std::vector<uint8_t>> v); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStrings( |
| JNIEnv* env, |
| base::span<const std::string> v); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStrings( |
| JNIEnv* env, |
| base::span<const std::u16string> v); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStringArray( |
| JNIEnv* env, |
| base::span<const std::vector<std::string>> v); |
| |
| BASE_EXPORT ScopedJavaLocalRef<jobjectArray> ToJavaArrayOfStringArray( |
| JNIEnv* env, |
| base::span<const std::vector<std::u16string>> v); |
| |
| // Converts a Java string array to a native array. |
| BASE_EXPORT void AppendJavaStringArrayToStringVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::u16string>* out); |
| |
| BASE_EXPORT void AppendJavaStringArrayToStringVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::string>* out); |
| |
| // Appends the Java bytes in |bytes_array| onto the end of |out|. |
| BASE_EXPORT void AppendJavaByteArrayToByteVector( |
| JNIEnv* env, |
| const JavaRef<jbyteArray>& byte_array, |
| std::vector<uint8_t>* out); |
| |
| // Replaces the content of |out| with the Java bytes in |byte_array|. |
| BASE_EXPORT void JavaByteArrayToByteVector( |
| JNIEnv* env, |
| const JavaRef<jbyteArray>& byte_array, |
| std::vector<uint8_t>* out); |
| |
| // Copy the contents of java |byte_array| into |dest|. The span must be larger |
| // than or equal to the array. |
| // Returns the number of bytes copied. |
| BASE_EXPORT size_t |
| JavaByteArrayToByteSpan(JNIEnv* env, |
| const JavaRef<jbyteArray>& byte_array, |
| base::span<uint8_t> dest); |
| |
| // Replaces the content of |out| with the Java bytes in |byte_array|. No UTF-8 |
| // conversion is performed. |
| BASE_EXPORT void JavaByteArrayToString(JNIEnv* env, |
| const JavaRef<jbyteArray>& byte_array, |
| std::string* out); |
| |
| // Replaces the content of |out| with the Java booleans in |boolean_array|. |
| BASE_EXPORT void JavaBooleanArrayToBoolVector( |
| JNIEnv* env, |
| const JavaRef<jbooleanArray>& boolean_array, |
| std::vector<bool>* out); |
| |
| // Replaces the content of |out| with the Java ints in |int_array|. |
| BASE_EXPORT void JavaIntArrayToIntVector(JNIEnv* env, |
| const JavaRef<jintArray>& int_array, |
| std::vector<int>* out); |
| |
| // Replaces the content of |out| with the Java longs in |long_array|. |
| BASE_EXPORT void JavaLongArrayToInt64Vector( |
| JNIEnv* env, |
| const JavaRef<jlongArray>& long_array, |
| std::vector<int64_t>* out); |
| |
| // Replaces the content of |out| with the Java longs in |long_array|. |
| BASE_EXPORT void JavaLongArrayToLongVector( |
| JNIEnv* env, |
| const JavaRef<jlongArray>& long_array, |
| std::vector<jlong>* out); |
| |
| // Replaces the content of |out| with the Java floats in |float_array|. |
| BASE_EXPORT void JavaFloatArrayToFloatVector( |
| JNIEnv* env, |
| const JavaRef<jfloatArray>& float_array, |
| std::vector<float>* out); |
| |
| // Replaces the content of |out| with the Java doubles in |double_array|. |
| BASE_EXPORT void JavaDoubleArrayToDoubleVector( |
| JNIEnv* env, |
| const JavaRef<jdoubleArray>& double_array, |
| std::vector<double>* out); |
| |
| // Assuming |array| is an byte[][] (array of byte arrays), replaces the |
| // content of |out| with the corresponding vector of strings. No UTF-8 |
| // conversion is performed. |
| BASE_EXPORT void JavaArrayOfByteArrayToStringVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::string>* out); |
| |
| // Assuming |array| is an byte[][] (array of byte arrays), replaces the |
| // content of |out| with the corresponding vector of vector of uint8. No UTF-8 |
| // conversion is performed. |
| BASE_EXPORT void JavaArrayOfByteArrayToBytesVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::vector<uint8_t>>* out); |
| |
| // Assuming |array| is an String[][] (array of String arrays), replaces the |
| // content of |out| with the corresponding vector of string vectors. |
| BASE_EXPORT void Java2dStringArrayTo2dStringVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::vector<std::string>>* out); |
| |
| // Assuming |array| is an String[][] (array of String arrays), replaces the |
| // content of |out| with the corresponding vector of string vectors. No UTF-8 |
| // conversion is performed. |
| BASE_EXPORT void Java2dStringArrayTo2dStringVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::vector<std::u16string>>* out); |
| |
| // Assuming |array| is an int[][] (array of int arrays), replaces the |
| // contents of |out| with the corresponding vectors of ints. |
| BASE_EXPORT void JavaArrayOfIntArrayToIntVector( |
| JNIEnv* env, |
| const JavaRef<jobjectArray>& array, |
| std::vector<std::vector<int>>* out); |
| |
| } // namespace base::android |
| |
| #endif // BASE_ANDROID_JNI_ARRAY_H_ |