From 9ab29b6c07d0995127ba647b2eab1c694e236661 Mon Sep 17 00:00:00 2001 From: Matthias Baesken Date: Wed, 18 May 2022 16:45:14 +0000 Subject: [PATCH] 8286869: unify os::dir_is_empty across posix platforms Reviewed-by: iklam, dholmes --- src/hotspot/os/aix/os_aix.cpp | 19 ------------------- src/hotspot/os/bsd/os_bsd.cpp | 19 ------------------- src/hotspot/os/linux/os_linux.cpp | 19 ------------------- src/hotspot/os/posix/os_posix.cpp | 19 +++++++++++++++++++ 4 files changed, 19 insertions(+), 57 deletions(-) diff --git a/src/hotspot/os/aix/os_aix.cpp b/src/hotspot/os/aix/os_aix.cpp index ca7fe300c2f..536ce97022c 100644 --- a/src/hotspot/os/aix/os_aix.cpp +++ b/src/hotspot/os/aix/os_aix.cpp @@ -2492,25 +2492,6 @@ bool os::message_box(const char* title, const char* message) { return buf[0] == 'y' || buf[0] == 'Y'; } -// Is a (classpath) directory empty? -bool os::dir_is_empty(const char* path) { - DIR *dir = NULL; - struct dirent *ptr; - - dir = opendir(path); - if (dir == NULL) return true; - - /* Scan the directory */ - bool result = true; - while (result && (ptr = readdir(dir)) != NULL) { - if (strcmp(ptr->d_name, ".") != 0 && strcmp(ptr->d_name, "..") != 0) { - result = false; - } - } - closedir(dir); - return result; -} - // This code originates from JDK's sysOpen and open64_w // from src/solaris/hpi/src/system_md.c diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index 443b82127e5..49b5ce1cb50 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -2207,25 +2207,6 @@ int os::compare_file_modified_times(const char* file1, const char* file2) { return diff; } -// Is a (classpath) directory empty? -bool os::dir_is_empty(const char* path) { - DIR *dir = NULL; - struct dirent *ptr; - - dir = opendir(path); - if (dir == NULL) return true; - - // Scan the directory - bool result = true; - while (result && (ptr = readdir(dir)) != NULL) { - if (strcmp(ptr->d_name, ".") != 0 && strcmp(ptr->d_name, "..") != 0) { - result = false; - } - } - closedir(dir); - return result; -} - // This code originates from JDK's sysOpen and open64_w // from src/solaris/hpi/src/system_md.c diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index 4c4434a60db..cf03dd21fa3 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -4832,25 +4832,6 @@ bool os::message_box(const char* title, const char* message) { return buf[0] == 'y' || buf[0] == 'Y'; } -// Is a (classpath) directory empty? -bool os::dir_is_empty(const char* path) { - DIR *dir = NULL; - struct dirent *ptr; - - dir = opendir(path); - if (dir == NULL) return true; - - // Scan the directory - bool result = true; - while (result && (ptr = readdir(dir)) != NULL) { - if (strcmp(ptr->d_name, ".") != 0 && strcmp(ptr->d_name, "..") != 0) { - result = false; - } - } - closedir(dir); - return result; -} - // This code originates from JDK's sysOpen and open64_w // from src/solaris/hpi/src/system_md.c diff --git a/src/hotspot/os/posix/os_posix.cpp b/src/hotspot/os/posix/os_posix.cpp index 9dbebcafc71..1e03ed2e731 100644 --- a/src/hotspot/os/posix/os_posix.cpp +++ b/src/hotspot/os/posix/os_posix.cpp @@ -247,6 +247,25 @@ int os::create_file_for_heap(const char* dir) { return fd; } +// Is a (classpath) directory empty? +bool os::dir_is_empty(const char* path) { + DIR *dir = NULL; + struct dirent *ptr; + + dir = ::opendir(path); + if (dir == NULL) return true; + + // Scan the directory + bool result = true; + while (result && (ptr = ::readdir(dir)) != NULL) { + if (strcmp(ptr->d_name, ".") != 0 && strcmp(ptr->d_name, "..") != 0) { + result = false; + } + } + ::closedir(dir); + return result; +} + static char* reserve_mmapped_memory(size_t bytes, char* requested_addr) { char * addr; int flags = MAP_PRIVATE NOT_AIX( | MAP_NORESERVE ) | MAP_ANONYMOUS;