From ba10a58e3b8d4dad58346140e58cdc711d0bcd43 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 17 Oct 2013 14:22:59 -0500 Subject: [PATCH] Support java.io.File#lastModified not only on Windows There was already non-Windows support, but it was put into the Windows-specific part. Move it outside. While at it, change the left-over 'st' to 'fileStat' to fix the compilation. Signed-off-by: Johannes Schindelin --- classpath/java-io.cpp | 70 +++++++++++++++++++++---------------------- 1 file changed, 35 insertions(+), 35 deletions(-) diff --git a/classpath/java-io.cpp b/classpath/java-io.cpp index b93b3f94ae..fd3493c8df 100644 --- a/classpath/java-io.cpp +++ b/classpath/java-io.cpp @@ -541,39 +541,6 @@ Java_java_io_File_exists(JNIEnv* e, jclass, jstring path) } } -#ifdef PLATFORM_WINDOWS - -extern "C" JNIEXPORT jlong JNICALL -Java_java_io_File_openDir(JNIEnv* e, jclass, jstring path) -{ - string_t chars = getChars(e, path); - if (chars) { - unsigned length = wcslen(chars); - unsigned size = length * sizeof(char_t); - - RUNTIME_ARRAY(char_t, buffer, length + 3); - memcpy(RUNTIME_ARRAY_BODY(buffer), chars, size); - memcpy(RUNTIME_ARRAY_BODY(buffer) + length, L"\\*", 6); - - releaseChars(e, path, chars); - - Directory* d = new (malloc(sizeof(Directory))) Directory; - #if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) - d->handle = FindFirstFileW(RUNTIME_ARRAY_BODY(buffer), &(d->data)); - #else - d->handle = FindFirstFileExW(RUNTIME_ARRAY_BODY(buffer), FindExInfoStandard, &(d->data), FindExSearchNameMatch, NULL, 0); - #endif - if (d->handle == INVALID_HANDLE_VALUE) { - d->dispose(); - d = 0; - } - - return reinterpret_cast(d); - } else { - return 0; - } -} - extern "C" JNIEXPORT jlong JNICALL Java_java_io_File_lastModified(JNIEnv* e, jclass, jstring path) { @@ -622,14 +589,47 @@ Java_java_io_File_lastModified(JNIEnv* e, jclass, jstring path) return 0; } - return (static_cast(st.st_mtim.tv_sec) * 1000) + - (static_cast(st.st_mtim.tv_nsec) / (1000*1000)); + return (static_cast(fileStat.st_mtim.tv_sec) * 1000) + + (static_cast(fileStat.st_mtim.tv_nsec) / (1000*1000)); #endif } return 0; } +#ifdef PLATFORM_WINDOWS + +extern "C" JNIEXPORT jlong JNICALL +Java_java_io_File_openDir(JNIEnv* e, jclass, jstring path) +{ + string_t chars = getChars(e, path); + if (chars) { + unsigned length = wcslen(chars); + unsigned size = length * sizeof(char_t); + + RUNTIME_ARRAY(char_t, buffer, length + 3); + memcpy(RUNTIME_ARRAY_BODY(buffer), chars, size); + memcpy(RUNTIME_ARRAY_BODY(buffer) + length, L"\\*", 6); + + releaseChars(e, path, chars); + + Directory* d = new (malloc(sizeof(Directory))) Directory; + #if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) + d->handle = FindFirstFileW(RUNTIME_ARRAY_BODY(buffer), &(d->data)); + #else + d->handle = FindFirstFileExW(RUNTIME_ARRAY_BODY(buffer), FindExInfoStandard, &(d->data), FindExSearchNameMatch, NULL, 0); + #endif + if (d->handle == INVALID_HANDLE_VALUE) { + d->dispose(); + d = 0; + } + + return reinterpret_cast(d); + } else { + return 0; + } +} + extern "C" JNIEXPORT jstring JNICALL Java_java_io_File_readDir(JNIEnv* e, jclass, jlong handle) {