diff --git a/src/java/File.cxx b/src/java/File.cxx index 0d8c789f3..4866953e3 100644 --- a/src/java/File.cxx +++ b/src/java/File.cxx @@ -54,7 +54,7 @@ Java::File::ToAbsolutePath(JNIEnv *env, jobject _file) noexcept LocalObject file(env, _file); - const jstring path = getAbsolutePath(env, file); + const jstring path = GetAbsolutePath(env, file); if (DiscardException(env) || path == nullptr) return nullptr; diff --git a/src/java/File.hxx b/src/java/File.hxx index e7a1a5363..b49cd30b8 100644 --- a/src/java/File.hxx +++ b/src/java/File.hxx @@ -31,6 +31,7 @@ #define JAVA_FILE_HXX #include "Object.hxx" +#include "String.hxx" #include @@ -51,11 +52,19 @@ public: static void Initialise(JNIEnv *env) noexcept; gcc_nonnull_all - static jstring getAbsolutePath(JNIEnv *env, jobject file) noexcept { + static jstring GetAbsolutePath(JNIEnv *env, jobject file) noexcept { return (jstring)env->CallObjectMethod(file, getAbsolutePath_method); } + String GetAbsolutePath() const noexcept { + return {GetEnv(), GetAbsolutePath(GetEnv(), Get())}; + } + + String GetAbsolutePathChecked() const noexcept { + return *this ? GetAbsolutePath() : nullptr; + } + /** * Invoke File.getAbsolutePath() and release the * specified File reference.