From 01f12fba648b8c0cb64870b00e6f0f3a7f0ba4c9 Mon Sep 17 00:00:00 2001 From: Jan Lahoda Date: Tue, 22 Jun 2021 07:34:30 +0000 Subject: [PATCH] 8266631: StandardJavaFileManager: getJavaFileObjects() impl violates the spec 8266596: StandardJavaFileManager: default impls of setLocationFromPaths(), getJavaFileObjectsFromPaths() methods don't throw IllegalArgumentException as specified 8266591: StandardJavaFileManager::getJavaFileObjectsFromPaths() methods contain a typo in their spec 8266590: StandardJavaFileManager::setLocationFromPaths() spec contains an error Reviewed-by: vromero, jjg --- .../javax/tools/StandardJavaFileManager.java | 36 +++++++++++-------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/src/java.compiler/share/classes/javax/tools/StandardJavaFileManager.java b/src/java.compiler/share/classes/javax/tools/StandardJavaFileManager.java index 2fee7e2673a..6dff9a13a2b 100644 --- a/src/java.compiler/share/classes/javax/tools/StandardJavaFileManager.java +++ b/src/java.compiler/share/classes/javax/tools/StandardJavaFileManager.java @@ -190,16 +190,16 @@ public interface StandardJavaFileManager extends JavaFileManager { * Returns file objects representing the given paths. * * @implSpec - * The default implementation converts each path to a file and calls - * {@link #getJavaFileObjectsFromFiles getJavaObjectsFromFiles}. - * IllegalArgumentException will be thrown if any of the paths - * cannot be converted to a file. + * The default implementation lazily converts each path to a file and calls + * {@link #getJavaFileObjectsFromFiles(Iterable) getJavaFileObjectsFromFiles}. + * {@code IllegalArgumentException} will be thrown + * if any of the paths cannot be converted to a file at the point the conversion happens. * * @param paths a list of paths * @return a list of file objects * @throws IllegalArgumentException if the list of paths includes * a directory or if this file manager does not support any of the - * given paths. + * given paths * * @since 13 */ @@ -212,10 +212,10 @@ public interface StandardJavaFileManager extends JavaFileManager { * Returns file objects representing the given paths. * * @implSpec - * The default implementation converts each path to a file and calls - * {@link #getJavaFileObjectsFromFiles getJavaObjectsFromFiles}. - * IllegalArgumentException will be thrown if any of the paths - * cannot be converted to a file. + * The default implementation lazily converts each path to a file and calls + * {@link #getJavaFileObjectsFromPaths(Collection) getJavaFileObjectsFromPaths}. + * {@code IllegalArgumentException} will be thrown + * if any of the paths cannot be converted to a file at the point the conversion happens. * * @param paths a list of paths * @return a list of file objects @@ -248,7 +248,8 @@ public interface StandardJavaFileManager extends JavaFileManager { * @param files an array of files * @return a list of file objects * @throws IllegalArgumentException if the array of files includes - * a directory + * a directory or if this file manager does not support any of the + * given paths * @throws NullPointerException if the given array contains null * elements */ @@ -262,10 +263,15 @@ public interface StandardJavaFileManager extends JavaFileManager { * getJavaFileObjectsFromPaths({@linkplain java.util.Arrays#asList Arrays.asList}(paths)) * * + * @implSpec + * The default implementation will only throw {@code NullPointerException} + * if {@linkplain #getJavaFileObjectsFromPaths(Collection)} throws it. + * * @param paths an array of paths * @return a list of file objects * @throws IllegalArgumentException if the array of files includes - * a directory + * a directory or if this file manager does not support any of the + * given paths * @throws NullPointerException if the given array contains null * elements * @@ -332,10 +338,10 @@ public interface StandardJavaFileManager extends JavaFileManager { * will be cancelled. * * @implSpec - * The default implementation converts each path to a file and calls - * {@link #getJavaFileObjectsFromFiles getJavaObjectsFromFiles}. - * {@linkplain IllegalArgumentException IllegalArgumentException} - * will be thrown if any of the paths cannot be converted to a file. + * The default implementation lazily converts each path to a file and calls + * {@link #setLocation setLocation}. + * {@code IllegalArgumentException} will be thrown if any of the paths cannot + * be converted to a file at the point the conversion happens. * * @param location a location * @param paths a list of paths, if {@code null} use the default