| 
									
										
										
										
											2023-01-05 13:25:55 +01:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*  jni_utils.h                                                           */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*                         This file is part of:                          */ | 
					
						
							|  |  |  | /*                             GODOT ENGINE                               */ | 
					
						
							|  |  |  | /*                        https://godotengine.org                         */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */ | 
					
						
							|  |  |  | /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur.                  */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* Permission is hereby granted, free of charge, to any person obtaining  */ | 
					
						
							|  |  |  | /* a copy of this software and associated documentation files (the        */ | 
					
						
							|  |  |  | /* "Software"), to deal in the Software without restriction, including    */ | 
					
						
							|  |  |  | /* without limitation the rights to use, copy, modify, merge, publish,    */ | 
					
						
							|  |  |  | /* distribute, sublicense, and/or sell copies of the Software, and to     */ | 
					
						
							|  |  |  | /* permit persons to whom the Software is furnished to do so, subject to  */ | 
					
						
							|  |  |  | /* the following conditions:                                              */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* The above copyright notice and this permission notice shall be         */ | 
					
						
							|  |  |  | /* included in all copies or substantial portions of the Software.        */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,        */ | 
					
						
							|  |  |  | /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF     */ | 
					
						
							|  |  |  | /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */ | 
					
						
							|  |  |  | /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY   */ | 
					
						
							|  |  |  | /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,   */ | 
					
						
							|  |  |  | /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE      */ | 
					
						
							|  |  |  | /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                 */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							| 
									
										
										
										
											2020-03-04 09:21:59 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-01 10:33:58 -06:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2020-03-04 09:21:59 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-20 10:10:17 -08:00
										 |  |  | #include "thread_jandroid.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-08 14:51:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "core/config/engine.h"
 | 
					
						
							| 
									
										
										
										
											2024-11-20 10:10:17 -08:00
										 |  |  | #include "core/string/ustring.h"
 | 
					
						
							| 
									
										
										
										
											2023-06-08 14:51:32 +02:00
										 |  |  | #include "core/variant/variant.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 09:21:59 -08:00
										 |  |  | #include <jni.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct jvalret { | 
					
						
							|  |  |  | 	jobject obj; | 
					
						
							|  |  |  | 	jvalue val; | 
					
						
							| 
									
										
										
										
											2020-04-02 01:20:12 +02:00
										 |  |  | 	jvalret() { obj = nullptr; } | 
					
						
							| 
									
										
										
										
											2020-03-04 09:21:59 -08:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | jvalret _variant_to_jvalue(JNIEnv *env, Variant::Type p_type, const Variant *p_arg, bool force_jobject = false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String _get_class_name(JNIEnv *env, jclass cls, bool *array); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Variant _jobject_to_variant(JNIEnv *env, jobject obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Variant::Type get_jni_type(const String &p_type); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-20 10:10:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Convert a Godot Callable to a org.godotengine.godot.variant.Callable java object. | 
					
						
							|  |  |  |  * @param p_env JNI environment instance | 
					
						
							|  |  |  |  * @param p_callable Callable parameter to convert. If null or invalid type, a null jobject is returned. | 
					
						
							|  |  |  |  * @return org.godotengine.godot.variant.Callable jobject or null | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | jobject callable_to_jcallable(JNIEnv *p_env, const Variant &p_callable); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert a org.godotengine.godot.variant.Callable java object to a Godot Callable variant. | 
					
						
							|  |  |  |  * @param p_env JNI environment instance | 
					
						
							|  |  |  |  * @param p_jcallable_obj org.godotengine.godot.variant.Callable java object to convert. | 
					
						
							|  |  |  |  * @return Callable variant | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | Callable jcallable_to_callable(JNIEnv *p_env, jobject p_jcallable_obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Converts a java.lang.CharSequence object to a Godot String. | 
					
						
							|  |  |  |  * @param p_env  JNI environment instance | 
					
						
							|  |  |  |  * @param p_charsequence java.lang.CharSequence object to convert | 
					
						
							|  |  |  |  * @return Godot String instance. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | String charsequence_to_string(JNIEnv *p_env, jobject p_charsequence); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Converts JNI jstring to Godot String. | 
					
						
							|  |  |  |  * @param source Source JNI string. If null an empty string is returned. | 
					
						
							|  |  |  |  * @param env JNI environment instance. If null obtained by get_jni_env(). | 
					
						
							|  |  |  |  * @return Godot string instance. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static inline String jstring_to_string(jstring source, JNIEnv *env = nullptr) { | 
					
						
							|  |  |  | 	String result; | 
					
						
							|  |  |  | 	if (source) { | 
					
						
							|  |  |  | 		if (!env) { | 
					
						
							|  |  |  | 			env = get_jni_env(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		const char *const source_utf8 = env->GetStringUTFChars(source, nullptr); | 
					
						
							|  |  |  | 		if (source_utf8) { | 
					
						
							| 
									
										
										
										
											2025-03-24 12:25:48 +01:00
										 |  |  | 			result.append_utf8(source_utf8); | 
					
						
							| 
									
										
										
										
											2024-11-20 10:10:17 -08:00
										 |  |  | 			env->ReleaseStringUTFChars(source, source_utf8); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return result; | 
					
						
							|  |  |  | } |