From 68c23b7878a1050f282d38956785b045573a3d28 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Fri, 28 Jan 2011 09:25:20 +0000 Subject: [PATCH] 7006126: (fs) Updates to file system API (1/2011) Reviewed-by: jjg --- .../tools/javac/nio/JavacPathFileManager.java | 23 ++++++++----------- .../sun/tools/javac/nio/PathFileObject.java | 23 ++++++++----------- .../javac/nio/compileTest/CompileTest.java | 3 +-- 3 files changed, 21 insertions(+), 28 deletions(-) diff --git a/langtools/src/share/classes/com/sun/tools/javac/nio/JavacPathFileManager.java b/langtools/src/share/classes/com/sun/tools/javac/nio/JavacPathFileManager.java index 5853f3f5af5..27165c34958 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/nio/JavacPathFileManager.java +++ b/langtools/src/share/classes/com/sun/tools/javac/nio/JavacPathFileManager.java @@ -39,7 +39,6 @@ import java.nio.file.FileVisitOption; import java.nio.file.FileVisitResult; import java.nio.file.Path; import java.nio.file.SimpleFileVisitor; -import java.nio.file.attribute.Attributes; import java.nio.file.attribute.BasicFileAttributes; import java.util.ArrayList; import java.util.Arrays; @@ -223,9 +222,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan Path path = pathIter.next(); if (pathIter.hasNext()) throw new IllegalArgumentException("path too long for directory"); - if (!path.exists()) - throw new FileNotFoundException(path + ": does not exist"); - else if (!isDirectory(path)) + if (!isDirectory(path)) throw new IOException(path + ": not a directory"); } @@ -326,7 +323,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan private void list(Path path, String packageName, final Set kinds, boolean recurse, final ListBuffer results) throws IOException { - if (!path.exists()) + if (!Files.exists(path)) return; final Path pathDir; @@ -341,7 +338,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan String sep = path.getFileSystem().getSeparator(); Path packageDir = packageName.isEmpty() ? pathDir : pathDir.resolve(packageName.replace(".", sep)); - if (!packageDir.exists()) + if (!Files.exists(packageDir)) return; /* Alternate impl of list, superceded by use of Files.walkFileTree */ @@ -353,7 +350,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan // DirectoryStream ds = dir.newDirectoryStream(); // try { // for (Path p: ds) { -// String name = p.getName().toString(); +// String name = p.getFileName().toString(); // if (isDirectory(p)) { // if (recurse && SourceVersion.isIdentifier(name)) { // queue.add(p); @@ -376,7 +373,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan new SimpleFileVisitor() { @Override public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) { - Path name = dir.getName(); + Path name = dir.getFileName(); if (name == null || SourceVersion.isIdentifier(name.toString())) // JSR 292? return FileVisitResult.CONTINUE; else @@ -385,7 +382,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan @Override public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) { - if (attrs.isRegularFile() && kinds.contains(getKind(file.getName().toString()))) { + if (attrs.isRegularFile() && kinds.contains(getKind(file.getFileName().toString()))) { JavaFileObject fe = PathFileObject.createDirectoryPathFileObject( JavacPathFileManager.this, file, pathDir); @@ -431,13 +428,13 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan for (Path p: getLocation(location)) { if (isDirectory(p)) { Path f = resolve(p, relativePath); - if (f.exists()) + if (Files.exists(f)) return PathFileObject.createDirectoryPathFileObject(this, f, p); } else { FileSystem fs = getFileSystem(p); if (fs != null) { Path file = getPath(fs, relativePath); - if (file.exists()) + if (Files.exists(file)) return PathFileObject.createJarPathFileObject(this, file); } } @@ -504,7 +501,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan private FileSystem getFileSystem(Path p) throws IOException { FileSystem fs = fileSystems.get(p); if (fs == null) { - fs = FileSystems.newFileSystem(p, Collections.emptyMap(), null); + fs = FileSystems.newFileSystem(p, null); fileSystems.put(p, fs); } return fs; @@ -530,7 +527,7 @@ public class JavacPathFileManager extends BaseFileManager implements PathFileMan } private static boolean isDirectory(Path path) throws IOException { - BasicFileAttributes attrs = Attributes.readBasicFileAttributes(path); + BasicFileAttributes attrs = Files.readAttributes(path, BasicFileAttributes.class); return attrs.isDirectory(); } diff --git a/langtools/src/share/classes/com/sun/tools/javac/nio/PathFileObject.java b/langtools/src/share/classes/com/sun/tools/javac/nio/PathFileObject.java index 5bbe88b9c07..46c1e651e53 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/nio/PathFileObject.java +++ b/langtools/src/share/classes/com/sun/tools/javac/nio/PathFileObject.java @@ -38,7 +38,6 @@ import java.nio.CharBuffer; import java.nio.charset.CharsetDecoder; import java.nio.file.Files; import java.nio.file.Path; -import java.nio.file.attribute.Attributes; import java.nio.file.attribute.BasicFileAttributes; import javax.lang.model.element.Modifier; import javax.lang.model.element.NestingKind; @@ -153,7 +152,7 @@ abstract class PathFileObject implements JavaFileObject { @Override public Kind getKind() { - return BaseFileManager.getKind(path.getName().toString()); + return BaseFileManager.getKind(path.getFileName().toString()); } @Override @@ -164,14 +163,14 @@ abstract class PathFileObject implements JavaFileObject { return false; } String sn = simpleName + kind.extension; - String pn = path.getName().toString(); + String pn = path.getFileName().toString(); if (pn.equals(sn)) { return true; } if (pn.equalsIgnoreCase(sn)) { try { // allow for Windows - return path.toRealPath(false).getName().toString().equals(sn); + return path.toRealPath(false).getFileName().toString().equals(sn); } catch (IOException e) { } } @@ -200,13 +199,13 @@ abstract class PathFileObject implements JavaFileObject { @Override public InputStream openInputStream() throws IOException { - return path.newInputStream(); + return Files.newInputStream(path); } @Override public OutputStream openOutputStream() throws IOException { ensureParentDirectoriesExist(); - return path.newOutputStream(); + return Files.newOutputStream(path); } @Override @@ -242,14 +241,13 @@ abstract class PathFileObject implements JavaFileObject { @Override public Writer openWriter() throws IOException { ensureParentDirectoriesExist(); - return new OutputStreamWriter(path.newOutputStream(), fileManager.getEncodingName()); + return new OutputStreamWriter(Files.newOutputStream(path), fileManager.getEncodingName()); } @Override public long getLastModified() { try { - BasicFileAttributes attrs = Attributes.readBasicFileAttributes(path); - return attrs.lastModifiedTime().toMillis(); + return Files.getLastModifiedTime(path).toMillis(); } catch (IOException e) { return -1; } @@ -258,7 +256,7 @@ abstract class PathFileObject implements JavaFileObject { @Override public boolean delete() { try { - path.delete(); + Files.delete(path); return true; } catch (IOException e) { return false; @@ -267,7 +265,7 @@ abstract class PathFileObject implements JavaFileObject { public boolean isSameFile(PathFileObject other) { try { - return path.isSameFile(other.path); + return Files.isSameFile(path, other.path); } catch (IOException e) { return false; } @@ -296,8 +294,7 @@ abstract class PathFileObject implements JavaFileObject { private long size() { try { - BasicFileAttributes attrs = Attributes.readBasicFileAttributes(path); - return attrs.size(); + return Files.size(path); } catch (IOException e) { return -1; } diff --git a/langtools/test/tools/javac/nio/compileTest/CompileTest.java b/langtools/test/tools/javac/nio/compileTest/CompileTest.java index 739b2d75ca3..e339b23186b 100644 --- a/langtools/test/tools/javac/nio/compileTest/CompileTest.java +++ b/langtools/test/tools/javac/nio/compileTest/CompileTest.java @@ -84,8 +84,7 @@ public class CompileTest { System.err.println("Test " + count + " " + Arrays.asList(opts) + " " + className); Path testSrcDir = Paths.get(System.getProperty("test.src")); Path testClassesDir = Paths.get(System.getProperty("test.classes")); - Path classes = Paths.get("classes." + count); - classes.createDirectory(); + Path classes = Files.createDirectory(Paths.get("classes." + count)); Context ctx = new Context(); PathFileManager fm = new JavacPathFileManager(ctx, true, null);