X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/35941eb6c9df14962bc71fd83b2907c8737b5b5f..67d66b0cf79b9fc02c0450f254584693dbf21d3b:/src/bindings/java/jxbt_utilities.hpp diff --git a/src/bindings/java/jxbt_utilities.hpp b/src/bindings/java/jxbt_utilities.hpp index 4106d32825..c882d5cb1e 100644 --- a/src/bindings/java/jxbt_utilities.hpp +++ b/src/bindings/java/jxbt_utilities.hpp @@ -57,4 +57,34 @@ void jxbt_throw_time_out_failure(JNIEnv* env, const std::string& details); /**Thrown when a task is canceled */ void jxbt_throw_task_cancelled(JNIEnv* env, const std::string& details); +class jstring_wrapper { + JNIEnv* env_ = nullptr; + jstring jstr_ = nullptr; + +public: + const char* value = nullptr; + + jstring_wrapper(JNIEnv* env, jstring jstr) : env_(env), jstr_(jstr) + { + if (jstr != nullptr) + value = env_->GetStringUTFChars(jstr_, nullptr); + } + void reset(JNIEnv* env, jstring jstr) + { + if (jstr_ != nullptr) + env_->ReleaseStringUTFChars(jstr_, value); + env_ = env; + jstr_ = jstr; + if (jstr != nullptr) + value = env_->GetStringUTFChars(jstr_, nullptr); + } + ~jstring_wrapper() + { + if (jstr_ != nullptr) + env_->ReleaseStringUTFChars(jstr_, value); + } + operator const char*() const { return value; } + operator const std::string() const { return std::string(value); } +}; + #endif