From 3261af24cf275c029d0cc2c485013980399feec3 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Thu, 16 Aug 2012 11:14:42 +0100 Subject: [PATCH] 7191556: (fs) UnixNativeDispatcher.getextmntent should be moved into platform specific code Reviewed-by: andrew --- jdk/make/java/nio/Makefile | 3 - jdk/make/java/nio/mapfile-bsd | 5 - jdk/make/java/nio/mapfile-linux | 2 +- jdk/make/java/nio/mapfile-solaris | 2 +- .../sun/nio/fs/DefaultFileTypeDetector.java | 5 +- .../classes/sun/nio/fs/LinuxFileSystem.java | 2 +- .../sun/nio/fs/LinuxFileSystemProvider.java | 6 + .../sun/nio/fs/LinuxNativeDispatcher.java | 13 ++- .../classes/sun/nio/fs/SolarisFileSystem.java | 2 +- .../sun/nio/fs/SolarisFileSystemProvider.java | 6 + .../sun/nio/fs/SolarisNativeDispatcher.java | 6 + .../sun/nio/fs/UnixFileSystemProvider.java | 14 +++ .../sun/nio/fs/UnixNativeDispatcher.java | 5 - .../native/sun/nio/fs/BsdNativeDispatcher.c | 8 +- .../native/sun/nio/fs/GnomeFileTypeDetector.c | 2 +- .../native/sun/nio/fs/LinuxNativeDispatcher.c | 70 ++++++++++++ .../sun/nio/fs/SolarisNativeDispatcher.c | 81 +++++++++++++- .../native/sun/nio/fs/UnixNativeDispatcher.c | 105 ------------------ 18 files changed, 201 insertions(+), 136 deletions(-) diff --git a/jdk/make/java/nio/Makefile b/jdk/make/java/nio/Makefile index 78b36de9cd3..f288e1ec9c0 100644 --- a/jdk/make/java/nio/Makefile +++ b/jdk/make/java/nio/Makefile @@ -277,7 +277,6 @@ FILES_java += \ sun/nio/ch/UnixAsynchronousServerSocketChannelImpl.java \ sun/nio/ch/UnixAsynchronousSocketChannelImpl.java \ \ - sun/nio/fs/GnomeFileTypeDetector.java \ sun/nio/fs/BsdFileStore.java \ sun/nio/fs/BsdFileSystem.java \ sun/nio/fs/BsdFileSystemProvider.java \ @@ -312,7 +311,6 @@ FILES_c += \ UnixAsynchronousServerSocketChannelImpl.c \ UnixAsynchronousSocketChannelImpl.c \ \ - GnomeFileTypeDetector.c \ BsdNativeDispatcher.c \ MacOSXNativeDispatcher.c \ UnixCopyFile.c \ @@ -329,7 +327,6 @@ FILES_export += \ sun/nio/ch/UnixAsynchronousServerSocketChannelImpl.java \ sun/nio/ch/UnixAsynchronousSocketChannelImpl.java \ \ - sun/nio/fs/GnomeFileTypeDetector.java \ sun/nio/fs/BsdNativeDispatcher.java \ sun/nio/fs/UnixCopyFile.java \ sun/nio/fs/UnixNativeDispatcher.java diff --git a/jdk/make/java/nio/mapfile-bsd b/jdk/make/java/nio/mapfile-bsd index b3f50fffef4..070646b708e 100644 --- a/jdk/make/java/nio/mapfile-bsd +++ b/jdk/make/java/nio/mapfile-bsd @@ -121,10 +121,6 @@ SUNWprivate_1.1 { Java_sun_nio_fs_BsdNativeDispatcher_getfsstat; Java_sun_nio_fs_BsdNativeDispatcher_fsstatEntry; Java_sun_nio_fs_BsdNativeDispatcher_endfsstat; - Java_sun_nio_fs_GnomeFileTypeDetector_initializeGio; - Java_sun_nio_fs_GnomeFileTypeDetector_probeUsingGio; - Java_sun_nio_fs_GnomeFileTypeDetector_initializeGnomeVfs; - Java_sun_nio_fs_GnomeFileTypeDetector_probeUsingGnomeVfs; Java_sun_nio_fs_UnixNativeDispatcher_init; Java_sun_nio_fs_UnixNativeDispatcher_getcwd; Java_sun_nio_fs_UnixNativeDispatcher_strerror; @@ -170,7 +166,6 @@ SUNWprivate_1.1 { Java_sun_nio_fs_UnixNativeDispatcher_getgrgid; Java_sun_nio_fs_UnixNativeDispatcher_getpwnam0; Java_sun_nio_fs_UnixNativeDispatcher_getgrnam0; - Java_sun_nio_fs_UnixNativeDispatcher_getextmntent; Java_sun_nio_fs_UnixCopyFile_transfer; handleSocketError; diff --git a/jdk/make/java/nio/mapfile-linux b/jdk/make/java/nio/mapfile-linux index 63c9cbf1443..4cc3b2910c1 100644 --- a/jdk/make/java/nio/mapfile-linux +++ b/jdk/make/java/nio/mapfile-linux @@ -143,6 +143,7 @@ SUNWprivate_1.1 { Java_sun_nio_fs_LinuxNativeDispatcher_fsetxattr0; Java_sun_nio_fs_LinuxNativeDispatcher_fremovexattr0; Java_sun_nio_fs_LinuxNativeDispatcher_setmntent0; + Java_sun_nio_fs_LinuxNativeDispatcher_getmntent; Java_sun_nio_fs_LinuxNativeDispatcher_endmntent; Java_sun_nio_fs_UnixNativeDispatcher_init; Java_sun_nio_fs_UnixNativeDispatcher_getcwd; @@ -189,7 +190,6 @@ SUNWprivate_1.1 { Java_sun_nio_fs_UnixNativeDispatcher_getgrgid; Java_sun_nio_fs_UnixNativeDispatcher_getpwnam0; Java_sun_nio_fs_UnixNativeDispatcher_getgrnam0; - Java_sun_nio_fs_UnixNativeDispatcher_getextmntent; Java_sun_nio_fs_UnixCopyFile_transfer; handleSocketError; diff --git a/jdk/make/java/nio/mapfile-solaris b/jdk/make/java/nio/mapfile-solaris index 5a4908e1f6d..e05ea725fe1 100644 --- a/jdk/make/java/nio/mapfile-solaris +++ b/jdk/make/java/nio/mapfile-solaris @@ -169,10 +169,10 @@ SUNWprivate_1.1 { Java_sun_nio_fs_UnixNativeDispatcher_getgrgid; Java_sun_nio_fs_UnixNativeDispatcher_getpwnam0; Java_sun_nio_fs_UnixNativeDispatcher_getgrnam0; - Java_sun_nio_fs_UnixNativeDispatcher_getextmntent; Java_sun_nio_fs_UnixCopyFile_transfer; Java_sun_nio_fs_SolarisNativeDispatcher_init; Java_sun_nio_fs_SolarisNativeDispatcher_facl; + Java_sun_nio_fs_SolarisNativeDispatcher_getextmntent; Java_sun_nio_fs_SolarisWatchService_init; Java_sun_nio_fs_SolarisWatchService_portCreate; Java_sun_nio_fs_SolarisWatchService_portAssociate; diff --git a/jdk/src/solaris/classes/sun/nio/fs/DefaultFileTypeDetector.java b/jdk/src/solaris/classes/sun/nio/fs/DefaultFileTypeDetector.java index b7c791da76c..9259faeb8fe 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/DefaultFileTypeDetector.java +++ b/jdk/src/solaris/classes/sun/nio/fs/DefaultFileTypeDetector.java @@ -25,12 +25,15 @@ package sun.nio.fs; +import java.nio.file.FileSystems; import java.nio.file.spi.FileTypeDetector; +import java.nio.file.spi.FileSystemProvider; public class DefaultFileTypeDetector { private DefaultFileTypeDetector() { } public static FileTypeDetector create() { - return new GnomeFileTypeDetector(); + FileSystemProvider provider = FileSystems.getDefault().provider(); + return ((UnixFileSystemProvider)provider).getFileTypeDetector(); } } diff --git a/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystem.java b/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystem.java index 89be8614a25..fb6f6d1318b 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystem.java +++ b/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystem.java @@ -82,7 +82,7 @@ class LinuxFileSystem extends UnixFileSystem { try { for (;;) { UnixMountEntry entry = new UnixMountEntry(); - int res = getextmntent(fp, entry); + int res = getmntent(fp, entry); if (res < 0) break; entries.add(entry); diff --git a/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystemProvider.java b/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystemProvider.java index 1045a7e00c6..4d6159865d7 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystemProvider.java +++ b/jdk/src/solaris/classes/sun/nio/fs/LinuxFileSystemProvider.java @@ -27,6 +27,7 @@ package sun.nio.fs; import java.nio.file.*; import java.nio.file.attribute.*; +import java.nio.file.spi.FileTypeDetector; import java.io.IOException; /** @@ -96,4 +97,9 @@ public class LinuxFileSystemProvider extends UnixFileSystemProvider { return super.readAttributes(file, type, options); } } + + @Override + FileTypeDetector getFileTypeDetector() { + return new GnomeFileTypeDetector(); + } } diff --git a/jdk/src/solaris/classes/sun/nio/fs/LinuxNativeDispatcher.java b/jdk/src/solaris/classes/sun/nio/fs/LinuxNativeDispatcher.java index 537eaa66cf8..d657fcb1a14 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/LinuxNativeDispatcher.java +++ b/jdk/src/solaris/classes/sun/nio/fs/LinuxNativeDispatcher.java @@ -51,9 +51,15 @@ class LinuxNativeDispatcher extends UnixNativeDispatcher { private static native long setmntent0(long pathAddress, long typeAddress) throws UnixException; - /** - * int endmntent(FILE* filep); - */ + /** + * int getmntent(FILE *fp, struct mnttab *mp, int len); + */ + static native int getmntent(long fp, UnixMountEntry entry) + throws UnixException; + + /** + * int endmntent(FILE* filep); + */ static native void endmntent(long stream) throws UnixException; /** @@ -90,7 +96,6 @@ class LinuxNativeDispatcher extends UnixNativeDispatcher { private static native void fsetxattr0(int filedes, long nameAddress, long valueAdddress, int valueLen) throws UnixException; - /** * fremovexattr(int filedes, const char *name); */ diff --git a/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystem.java b/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystem.java index 9aa9e533b8a..14bc339cbc5 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystem.java +++ b/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystem.java @@ -30,7 +30,7 @@ import java.io.IOException; import java.util.*; import java.security.AccessController; import sun.security.action.GetPropertyAction; -import static sun.nio.fs.UnixNativeDispatcher.*; +import static sun.nio.fs.SolarisNativeDispatcher.*; /** * Solaris implementation of FileSystem diff --git a/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java b/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java index 5564a26235c..fec87c7a27b 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java +++ b/jdk/src/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java @@ -27,6 +27,7 @@ package sun.nio.fs; import java.nio.file.*; import java.nio.file.attribute.*; +import java.nio.file.spi.FileTypeDetector; import java.io.IOException; /** @@ -79,4 +80,9 @@ public class SolarisFileSystemProvider extends UnixFileSystemProvider { Util.followLinks(options)); return super.getFileAttributeView(obj, name, options); } + + @Override + FileTypeDetector getFileTypeDetector() { + return new GnomeFileTypeDetector(); + } } diff --git a/jdk/src/solaris/classes/sun/nio/fs/SolarisNativeDispatcher.java b/jdk/src/solaris/classes/sun/nio/fs/SolarisNativeDispatcher.java index 9adedc2fa07..3d54b75cb0d 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/SolarisNativeDispatcher.java +++ b/jdk/src/solaris/classes/sun/nio/fs/SolarisNativeDispatcher.java @@ -35,6 +35,12 @@ import java.security.PrivilegedAction; class SolarisNativeDispatcher extends UnixNativeDispatcher { private SolarisNativeDispatcher() { } + /** + * int getextmntent(FILE *fp, struct extmnttab *mp, int len); + */ + static native int getextmntent(long fp, UnixMountEntry entry) + throws UnixException; + /** * int facl(int filedes, int cmd, int nentries, void aclbufp) */ diff --git a/jdk/src/solaris/classes/sun/nio/fs/UnixFileSystemProvider.java b/jdk/src/solaris/classes/sun/nio/fs/UnixFileSystemProvider.java index 49f69a54648..5058f3147cb 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/UnixFileSystemProvider.java +++ b/jdk/src/solaris/classes/sun/nio/fs/UnixFileSystemProvider.java @@ -27,6 +27,7 @@ package sun.nio.fs; import java.nio.file.*; import java.nio.file.attribute.*; +import java.nio.file.spi.FileTypeDetector; import java.nio.channels.*; import java.net.URI; import java.util.concurrent.ExecutorService; @@ -495,4 +496,17 @@ public abstract class UnixFileSystemProvider return null; // keep compiler happy } } + + /** + * Returns a {@code FileTypeDetector} for this platform. + */ + FileTypeDetector getFileTypeDetector() { + return new AbstractFileTypeDetector() { + @Override + public String implProbeContentType(Path file) { + return null; + } + }; + } + } diff --git a/jdk/src/solaris/classes/sun/nio/fs/UnixNativeDispatcher.java b/jdk/src/solaris/classes/sun/nio/fs/UnixNativeDispatcher.java index 88659888566..5672319106b 100644 --- a/jdk/src/solaris/classes/sun/nio/fs/UnixNativeDispatcher.java +++ b/jdk/src/solaris/classes/sun/nio/fs/UnixNativeDispatcher.java @@ -497,11 +497,6 @@ class UnixNativeDispatcher { } private static native int getgrnam0(long nameAddress) throws UnixException; - /** - * int getextmntent(FILE *fp, struct extmnttab *mp, int len); - */ - static native int getextmntent(long fp, UnixMountEntry entry) throws UnixException; - /** * statvfs(const char* path, struct statvfs *buf) */ diff --git a/jdk/src/solaris/native/sun/nio/fs/BsdNativeDispatcher.c b/jdk/src/solaris/native/sun/nio/fs/BsdNativeDispatcher.c index 80342efa3ab..71ecd9058de 100644 --- a/jdk/src/solaris/native/sun/nio/fs/BsdNativeDispatcher.c +++ b/jdk/src/solaris/native/sun/nio/fs/BsdNativeDispatcher.c @@ -46,8 +46,6 @@ static jfieldID entry_name; static jfieldID entry_dir; static jfieldID entry_fstype; static jfieldID entry_options; -static jfieldID entry_dev; - struct fsstat_iter { struct statfs *buf; @@ -81,7 +79,6 @@ Java_sun_nio_fs_BsdNativeDispatcher_initIDs(JNIEnv* env, jclass this) entry_dir = (*env)->GetFieldID(env, clazz, "dir", "[B"); entry_fstype = (*env)->GetFieldID(env, clazz, "fstype", "[B"); entry_options = (*env)->GetFieldID(env, clazz, "opts", "[B"); - entry_dev = (*env)->GetFieldID(env, clazz, "dev", "J"); } JNIEXPORT jlong JNICALL @@ -160,7 +157,6 @@ Java_sun_nio_fs_BsdNativeDispatcher_fsstatEntry(JNIEnv* env, jclass this, options="ro"; else options=""; - dev = 0; iter->pos++; @@ -192,9 +188,6 @@ Java_sun_nio_fs_BsdNativeDispatcher_fsstatEntry(JNIEnv* env, jclass this, (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)options); (*env)->SetObjectField(env, entry, entry_options, bytes); - if (dev != 0) - (*env)->SetLongField(env, entry, entry_dev, (jlong)dev); - return 0; } @@ -208,3 +201,4 @@ Java_sun_nio_fs_BsdNativeDispatcher_endfsstat(JNIEnv* env, jclass this, jlong va free(iter); } } + diff --git a/jdk/src/solaris/native/sun/nio/fs/GnomeFileTypeDetector.c b/jdk/src/solaris/native/sun/nio/fs/GnomeFileTypeDetector.c index 535a1819928..0bd8dbabf86 100644 --- a/jdk/src/solaris/native/sun/nio/fs/GnomeFileTypeDetector.c +++ b/jdk/src/solaris/native/sun/nio/fs/GnomeFileTypeDetector.c @@ -35,7 +35,7 @@ #include #endif -#if defined(__linux__) || defined(__APPLE__) +#if defined(__linux__) #include #endif diff --git a/jdk/src/solaris/native/sun/nio/fs/LinuxNativeDispatcher.c b/jdk/src/solaris/native/sun/nio/fs/LinuxNativeDispatcher.c index de329d55916..5a158fcaa76 100644 --- a/jdk/src/solaris/native/sun/nio/fs/LinuxNativeDispatcher.c +++ b/jdk/src/solaris/native/sun/nio/fs/LinuxNativeDispatcher.c @@ -29,6 +29,7 @@ #include "jlong.h" #include +#include #include #include #include @@ -45,6 +46,11 @@ fsetxattr_func* my_fsetxattr_func = NULL; fremovexattr_func* my_fremovexattr_func = NULL; flistxattr_func* my_flistxattr_func = NULL; +static jfieldID entry_name; +static jfieldID entry_dir; +static jfieldID entry_fstype; +static jfieldID entry_options; + static void throwUnixException(JNIEnv* env, int errnum) { jobject x = JNU_NewObjectByName(env, "sun/nio/fs/UnixException", "(I)V", errnum); @@ -60,6 +66,15 @@ Java_sun_nio_fs_LinuxNativeDispatcher_init(JNIEnv *env, jclass clazz) my_fsetxattr_func = (fsetxattr_func*)dlsym(RTLD_DEFAULT, "fsetxattr"); my_fremovexattr_func = (fremovexattr_func*)dlsym(RTLD_DEFAULT, "fremovexattr"); my_flistxattr_func = (flistxattr_func*)dlsym(RTLD_DEFAULT, "flistxattr"); + + clazz = (*env)->FindClass(env, "sun/nio/fs/UnixMountEntry"); + if (clazz == NULL) + return; + + entry_name = (*env)->GetFieldID(env, clazz, "name", "[B"); + entry_dir = (*env)->GetFieldID(env, clazz, "dir", "[B"); + entry_fstype = (*env)->GetFieldID(env, clazz, "fstype", "[B"); + entry_options = (*env)->GetFieldID(env, clazz, "opts", "[B"); } JNIEXPORT jint JNICALL @@ -151,6 +166,61 @@ Java_sun_nio_fs_LinuxNativeDispatcher_setmntent0(JNIEnv* env, jclass this, jlong return ptr_to_jlong(fp); } +JNIEXPORT jint JNICALL +Java_sun_nio_fs_LinuxNativeDispatcher_getmntent(JNIEnv* env, jclass this, + jlong value, jobject entry) +{ + struct mntent ent; + char buf[1024]; + int buflen = sizeof(buf); + struct mntent* m; + FILE* fp = jlong_to_ptr(value); + jsize len; + jbyteArray bytes; + char* name; + char* dir; + char* fstype; + char* options; + + m = getmntent_r(fp, &ent, (char*)&buf, buflen); + if (m == NULL) + return -1; + name = m->mnt_fsname; + dir = m->mnt_dir; + fstype = m->mnt_type; + options = m->mnt_opts; + + len = strlen(name); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)name); + (*env)->SetObjectField(env, entry, entry_name, bytes); + + len = strlen(dir); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)dir); + (*env)->SetObjectField(env, entry, entry_dir, bytes); + + len = strlen(fstype); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)fstype); + (*env)->SetObjectField(env, entry, entry_fstype, bytes); + + len = strlen(options); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)options); + (*env)->SetObjectField(env, entry, entry_options, bytes); + + return 0; +} + JNIEXPORT void JNICALL Java_sun_nio_fs_LinuxNativeDispatcher_endmntent(JNIEnv* env, jclass this, jlong stream) { diff --git a/jdk/src/solaris/native/sun/nio/fs/SolarisNativeDispatcher.c b/jdk/src/solaris/native/sun/nio/fs/SolarisNativeDispatcher.c index 9bd45566dfe..5c93feef094 100644 --- a/jdk/src/solaris/native/sun/nio/fs/SolarisNativeDispatcher.c +++ b/jdk/src/solaris/native/sun/nio/fs/SolarisNativeDispatcher.c @@ -28,12 +28,22 @@ #include "jvm.h" #include "jlong.h" -#include +#include #include #include +#include +#include + +#include "jni.h" #include "sun_nio_fs_SolarisNativeDispatcher.h" +static jfieldID entry_name; +static jfieldID entry_dir; +static jfieldID entry_fstype; +static jfieldID entry_options; +static jfieldID entry_dev; + static void throwUnixException(JNIEnv* env, int errnum) { jobject x = JNU_NewObjectByName(env, "sun/nio/fs/UnixException", "(I)V", errnum); @@ -44,6 +54,15 @@ static void throwUnixException(JNIEnv* env, int errnum) { JNIEXPORT void JNICALL Java_sun_nio_fs_SolarisNativeDispatcher_init(JNIEnv *env, jclass clazz) { + clazz = (*env)->FindClass(env, "sun/nio/fs/UnixMountEntry"); + if (clazz == NULL) + return; + + entry_name = (*env)->GetFieldID(env, clazz, "name", "[B"); + entry_dir = (*env)->GetFieldID(env, clazz, "dir", "[B"); + entry_fstype = (*env)->GetFieldID(env, clazz, "fstype", "[B"); + entry_options = (*env)->GetFieldID(env, clazz, "opts", "[B"); + entry_dev = (*env)->GetFieldID(env, clazz, "dev", "J"); } JNIEXPORT jint JNICALL @@ -59,3 +78,63 @@ Java_sun_nio_fs_SolarisNativeDispatcher_facl(JNIEnv* env, jclass this, jint fd, } return (jint)n; } + +JNIEXPORT jint JNICALL +Java_sun_nio_fs_SolarisNativeDispatcher_getextmntent(JNIEnv* env, jclass this, + jlong value, jobject entry) +{ + struct extmnttab ent; + FILE* fp = jlong_to_ptr(value); + jsize len; + jbyteArray bytes; + char* name; + char* dir; + char* fstype; + char* options; + dev_t dev; + + if (getextmntent(fp, &ent, 0)) + return -1; + name = ent.mnt_special; + dir = ent.mnt_mountp; + fstype = ent.mnt_fstype; + options = ent.mnt_mntopts; + dev = makedev(ent.mnt_major, ent.mnt_minor); + if (dev == NODEV) { + throwUnixException(env, errno); + return -1; + } + + len = strlen(name); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)name); + (*env)->SetObjectField(env, entry, entry_name, bytes); + + len = strlen(dir); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)dir); + (*env)->SetObjectField(env, entry, entry_dir, bytes); + + len = strlen(fstype); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)fstype); + (*env)->SetObjectField(env, entry, entry_fstype, bytes); + + len = strlen(options); + bytes = (*env)->NewByteArray(env, len); + if (bytes == NULL) + return -1; + (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)options); + (*env)->SetObjectField(env, entry, entry_options, bytes); + + if (dev != 0) + (*env)->SetLongField(env, entry, entry_dev, (jlong)dev); + + return 0; +} diff --git a/jdk/src/solaris/native/sun/nio/fs/UnixNativeDispatcher.c b/jdk/src/solaris/native/sun/nio/fs/UnixNativeDispatcher.c index f921574512a..09ee01bcb11 100644 --- a/jdk/src/solaris/native/sun/nio/fs/UnixNativeDispatcher.c +++ b/jdk/src/solaris/native/sun/nio/fs/UnixNativeDispatcher.c @@ -40,13 +40,10 @@ #ifdef __solaris__ #include -#include -#include #endif #ifdef __linux__ #include -#include #endif #ifdef _ALLBSD_SOURCE @@ -1083,105 +1080,3 @@ Java_sun_nio_fs_UnixNativeDispatcher_getgrnam0(JNIEnv* env, jclass this, return gid; } - -JNIEXPORT jint JNICALL -Java_sun_nio_fs_UnixNativeDispatcher_getextmntent(JNIEnv* env, jclass this, - jlong value, jobject entry) -{ -#ifdef __solaris__ - struct extmnttab ent; -#elif defined(_ALLBSD_SOURCE) - char buf[1024]; - char *str; - char *last; -#else - struct mntent ent; - char buf[1024]; - int buflen = sizeof(buf); - struct mntent* m; -#endif - FILE* fp = jlong_to_ptr(value); - jsize len; - jbyteArray bytes; - char* name; - char* dir; - char* fstype; - char* options; - dev_t dev; - -#ifdef __solaris__ - if (getextmntent(fp, &ent, 0)) - return -1; - name = ent.mnt_special; - dir = ent.mnt_mountp; - fstype = ent.mnt_fstype; - options = ent.mnt_mntopts; - dev = makedev(ent.mnt_major, ent.mnt_minor); - if (dev == NODEV) { - /* possible bug on Solaris 8 and 9 */ - throwUnixException(env, errno); - return -1; - } -#elif defined(_ALLBSD_SOURCE) -again: - if (!(str = fgets(buf, sizeof(buf), fp))) - return -1; - - name = strtok_r(str, " \t\n", &last); - if (name == NULL) - return -1; - - // skip comments - if (*name == '#') - goto again; - - dir = strtok_r((char *)NULL, " \t\n", &last); - fstype = strtok_r((char *)NULL, " \t\n", &last); - options = strtok_r((char *)NULL, " \t\n", &last); - if (options == NULL) - return -1; - dev = 0; -#else - m = getmntent_r(fp, &ent, (char*)&buf, buflen); - if (m == NULL) - return -1; - name = m->mnt_fsname; - dir = m->mnt_dir; - fstype = m->mnt_type; - options = m->mnt_opts; - dev = 0; -#endif - - len = strlen(name); - bytes = (*env)->NewByteArray(env, len); - if (bytes == NULL) - return -1; - (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)name); - (*env)->SetObjectField(env, entry, entry_name, bytes); - - len = strlen(dir); - bytes = (*env)->NewByteArray(env, len); - if (bytes == NULL) - return -1; - (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)dir); - (*env)->SetObjectField(env, entry, entry_dir, bytes); - - len = strlen(fstype); - bytes = (*env)->NewByteArray(env, len); - if (bytes == NULL) - return -1; - (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)fstype); - (*env)->SetObjectField(env, entry, entry_fstype, bytes); - - len = strlen(options); - bytes = (*env)->NewByteArray(env, len); - if (bytes == NULL) - return -1; - (*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)options); - (*env)->SetObjectField(env, entry, entry_options, bytes); - - if (dev != 0) - (*env)->SetLongField(env, entry, entry_dev, (jlong)dev); - - return 0; -}