Extract rust_vec_to_java() utility function

This commit is contained in:
Jack Grigg 2019-02-11 16:20:11 +00:00
parent 5dfadd4393
commit 6d86b2cf16
No known key found for this signature in database
GPG Key ID: 1B8D649257DB0829
2 changed files with 43 additions and 14 deletions

View File

@ -9,7 +9,7 @@ const SAPLING_CONSENSUS_BRANCH_ID: u32 = 0x76b8_09bb;
use android_logger::Filter; use android_logger::Filter;
use jni::{ use jni::{
objects::{JClass, JString}, objects::{JClass, JString},
sys::{jboolean, jbyteArray, jint, jlong, jobjectArray, jsize, jstring, JNI_FALSE, JNI_TRUE}, sys::{jboolean, jbyteArray, jint, jlong, jobjectArray, jstring, JNI_FALSE, JNI_TRUE},
JNIEnv, JNIEnv,
}; };
use log::Level; use log::Level;
@ -97,21 +97,18 @@ pub unsafe extern "C" fn Java_cash_z_wallet_sdk_jni_JniConverter_initAccountsTab
vec![] vec![]
}; };
let jempty = env.new_string("").expect("Couldn't create Java string!"); utils::rust_vec_to_java(
let jret = env &env,
.new_object_array(ret.len() as jsize, "java/lang/String", *jempty) ret,
.expect("Couldn't create Java array!"); "java/lang/String",
for (i, extsk) in ret.into_iter().enumerate() { |env, extsk| {
let jextsk = env env.new_string(encode_extended_spending_key(
.new_string(encode_extended_spending_key(
HRP_SAPLING_EXTENDED_SPENDING_KEY_TEST, HRP_SAPLING_EXTENDED_SPENDING_KEY_TEST,
&extsk, &extsk,
)) ))
.expect("Couldn't create Java string!"); },
env.set_object_array_element(jret, i as jsize, *jextsk) |env| env.new_string(""),
.expect("Couldn't set Java array element!"); )
}
jret
} }
#[no_mangle] #[no_mangle]

View File

@ -1,7 +1,39 @@
use jni::{objects::JString, JNIEnv}; use jni::{
descriptors::Desc,
errors::Result as JNIResult,
objects::{JClass, JObject, JString},
sys::{jobjectArray, jsize},
JNIEnv,
};
use std::ops::Deref;
pub(crate) fn java_string_to_rust(env: &JNIEnv<'_>, jstring: JString<'_>) -> String { pub(crate) fn java_string_to_rust(env: &JNIEnv<'_>, jstring: JString<'_>) -> String {
env.get_string(jstring) env.get_string(jstring)
.expect("Couldn't get Java string!") .expect("Couldn't get Java string!")
.into() .into()
} }
pub(crate) fn rust_vec_to_java<'a, T, U, V, F, G>(
env: &JNIEnv<'a>,
data: Vec<T>,
element_class: U,
element_map: F,
empty_element: G,
) -> jobjectArray
where
U: Desc<'a, JClass<'a>>,
V: Deref<Target = JObject<'a>>,
F: Fn(&JNIEnv<'a>, T) -> JNIResult<V>,
G: Fn(&JNIEnv<'a>) -> JNIResult<V>,
{
let jempty = empty_element(env).expect("Couldn't create Java string!");
let jret = env
.new_object_array(data.len() as jsize, element_class, *jempty)
.expect("Couldn't create Java array!");
for (i, elem) in data.into_iter().enumerate() {
let jelem = element_map(env, elem).expect("Couldn't map element to Java!");
env.set_object_array_element(jret, i as jsize, *jelem)
.expect("Couldn't set Java array element!");
}
jret
}