Update td_jni.cpp and td_jni.cpp

This commit is contained in:
Andrea Cavalli 2020-10-12 17:01:41 +02:00
parent 7c23b0ccf6
commit 8e8660ad07
2 changed files with 34 additions and 32 deletions

View File

@ -67,7 +67,6 @@ static jint Client_nativeClientReceive(JNIEnv *env, jclass clazz, jintArray clie
break; break;
} }
response = client->receive(0);
response = manager->receive(0); response = manager->receive(0);
} }
return result_size; return result_size;

View File

@ -27,31 +27,35 @@ static td::td_api::object_ptr<td::td_api::Function> fetch_function(JNIEnv *env,
return result; return result;
} }
static td::Client *get_client(jlong client_id) { static td::ClientManager *get_manager() {
return reinterpret_cast<td::Client *>(static_cast<std::uintptr_t>(client_id)); return td::ClientManager::get_manager_singleton();
} }
static jlong Client_createNativeClient(JNIEnv *env, jclass clazz) { static jint Client_createNativeClient(JNIEnv *env, jclass clazz) {
return static_cast<jlong>(reinterpret_cast<std::uintptr_t>(new td::Client())); return static_cast<jint>(get_manager()->create_client());
} }
static void Client_nativeClientSend(JNIEnv *env, jclass clazz, jlong client_id, jlong id, jobject function) { static void Client_nativeClientSend(JNIEnv *env, jclass clazz, jint client_id, jlong id, jobject function) {
get_client(client_id)->send({static_cast<std::uint64_t>(id), fetch_function(env, function)}); get_manager()->send(static_cast<std::int32_t>(client_id), static_cast<std::uint64_t>(id),
fetch_function(env, function));
} }
static jint Client_nativeClientReceive(JNIEnv *env, jclass clazz, jlong client_id, jlongArray ids, jobjectArray events, static jint Client_nativeClientReceive(JNIEnv *env, jclass clazz, jintArray client_ids, jlongArray ids,
jdouble timeout) { jobjectArray events, jdouble timeout) {
auto client = get_client(client_id); jsize events_size = env->GetArrayLength(ids); // client_ids, ids and events must be of equal size
jsize events_size = env->GetArrayLength(ids); // ids and events size must be of equal size
if (events_size == 0) { if (events_size == 0) {
return 0; return 0;
} }
jsize result_size = 0; jsize result_size = 0;
auto response = client->receive(timeout); auto *manager = get_manager();
auto response = manager->receive(timeout);
while (response.object) { while (response.object) {
jlong result_id = static_cast<jlong>(response.id); jint client_id = static_cast<jint>(response.client_id);
env->SetLongArrayRegion(ids, result_size, 1, &result_id); env->SetIntArrayRegion(client_ids, result_size, 1, &client_id);
jlong request_id = static_cast<jlong>(response.request_id);
env->SetLongArrayRegion(ids, result_size, 1, &request_id);
jobject object; jobject object;
response.object->store(env, object); response.object->store(env, object);
@ -63,24 +67,27 @@ static jint Client_nativeClientReceive(JNIEnv *env, jclass clazz, jlong client_i
break; break;
} }
response = client->receive(0); response = manager->receive(0);
} }
return result_size; return result_size;
} }
static jint Client_nativeClientReceiveAdvanced(JNIEnv *env, jclass clazz, jlong client_id, jlongArray ids, jobjectArray events, static jint Client_nativeClientReceiveAdvanced(JNIEnv *env, jclass clazz, jintArray client_ids, jlongArray ids,
jdouble timeout, jboolean include_responses, jboolean include_updates) { jobjectArray events, jdouble timeout, jboolean include_responses, jboolean include_updates) {
auto client = get_client(client_id); jsize events_size = env->GetArrayLength(ids); // client_ids, ids and events must be of equal size
jsize events_size = env->GetArrayLength(ids); // ids and events size must be of equal size
if (events_size == 0) { if (events_size == 0) {
return 0; return 0;
} }
jsize result_size = 0; jsize result_size = 0;
auto response = client->receive(timeout, include_responses, include_updates); auto *manager = get_manager();
auto response = manager->receive(timeout, include_responses, include_updates);
while (response.object) { while (response.object) {
jlong result_id = static_cast<jlong>(response.id); jint client_id = static_cast<jint>(response.client_id);
env->SetLongArrayRegion(ids, result_size, 1, &result_id); env->SetIntArrayRegion(client_ids, result_size, 1, &client_id);
jlong request_id = static_cast<jlong>(response.request_id);
env->SetLongArrayRegion(ids, result_size, 1, &request_id);
jobject object; jobject object;
response.object->store(env, object); response.object->store(env, object);
@ -92,21 +99,17 @@ static jint Client_nativeClientReceiveAdvanced(JNIEnv *env, jclass clazz, jlong
break; break;
} }
response = client->receive(0, include_responses, include_updates); response = manager->receive(0, include_responses, include_updates);
} }
return result_size; return result_size;
} }
static jobject Client_nativeClientExecute(JNIEnv *env, jclass clazz, jobject function) { static jobject Client_nativeClientExecute(JNIEnv *env, jclass clazz, jobject function) {
jobject result; jobject result;
td::Client::execute({0, fetch_function(env, function)}).object->store(env, result); td::ClientManager::execute(fetch_function(env, function))->store(env, result);
return result; return result;
} }
static void Client_destroyNativeClient(JNIEnv *env, jclass clazz, jlong client_id) {
delete get_client(client_id);
}
static void Log_setVerbosityLevel(JNIEnv *env, jclass clazz, jint new_log_verbosity_level) { static void Log_setVerbosityLevel(JNIEnv *env, jclass clazz, jint new_log_verbosity_level) {
td::Log::set_verbosity_level(static_cast<int>(new_log_verbosity_level)); td::Log::set_verbosity_level(static_cast<int>(new_log_verbosity_level));
} }
@ -163,10 +166,10 @@ static jint register_native(JavaVM *vm) {
#define TD_OBJECT "L" PACKAGE_NAME "/TdApi$Object;" #define TD_OBJECT "L" PACKAGE_NAME "/TdApi$Object;"
#define TD_FUNCTION "L" PACKAGE_NAME "/TdApi$Function;" #define TD_FUNCTION "L" PACKAGE_NAME "/TdApi$Function;"
register_method(client_class, "createNativeClient", "()J", Client_createNativeClient); register_method(client_class, "createNativeClient", "()I", Client_createNativeClient);
register_method(client_class, "nativeClientSend", "(JJ" TD_FUNCTION ")V", Client_nativeClientSend); register_method(client_class, "nativeClientSend", "(IJ" TD_FUNCTION ")V", Client_nativeClientSend);
register_method(client_class, "nativeClientReceive", "(J[J[" TD_OBJECT "D)I", Client_nativeClientReceive); register_method(client_class, "nativeClientReceive", "([I[J[" TD_OBJECT "D)I", Client_nativeClientReceive);
register_method(client_class, "nativeClientReceive", "(J[J[" TD_OBJECT "DZZ)I", Client_nativeClientReceiveAdvanced); register_method(client_class, "nativeClientReceive", "([I[J[" TD_OBJECT "DZZ)I", Client_nativeClientReceiveAdvanced);
register_method(client_class, "nativeClientExecute", "(" TD_FUNCTION ")" TD_OBJECT, Client_nativeClientExecute); register_method(client_class, "nativeClientExecute", "(" TD_FUNCTION ")" TD_OBJECT, Client_nativeClientExecute);
register_method(client_class, "destroyNativeClient", "(J)V", Client_destroyNativeClient); register_method(client_class, "destroyNativeClient", "(J)V", Client_destroyNativeClient);