From 6b4b676550c2eaf38afcbc5820796f586edc4f1e Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Wed, 16 Dec 2020 22:21:54 +0000 Subject: [PATCH] 8241353: NPE in ToolProvider.getSystemJavaCompiler Reviewed-by: vromero --- .../share/classes/javax/tools/ToolProvider.java | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/java.compiler/share/classes/javax/tools/ToolProvider.java b/src/java.compiler/share/classes/javax/tools/ToolProvider.java index 74b4f45b3fd..ad7c749b018 100644 --- a/src/java.compiler/share/classes/javax/tools/ToolProvider.java +++ b/src/java.compiler/share/classes/javax/tools/ToolProvider.java @@ -27,7 +27,7 @@ package javax.tools; import java.security.AccessController; import java.security.PrivilegedAction; -import java.util.Iterator; +import java.util.Objects; import java.util.ServiceConfigurationError; import java.util.ServiceLoader; @@ -118,8 +118,7 @@ public class ToolProvider { try { ServiceLoader sl = ServiceLoader.load(clazz, ClassLoader.getSystemClassLoader()); - for (Iterator iter = sl.iterator(); iter.hasNext(); ) { - T tool = iter.next(); + for (T tool : sl) { if (matches(tool, moduleName)) return tool; } @@ -140,7 +139,7 @@ public class ToolProvider { PrivilegedAction pa = () -> { Module toolModule = tool.getClass().getModule(); String toolModuleName = toolModule.getName(); - return toolModuleName.equals(moduleName); + return Objects.equals(toolModuleName, moduleName); }; return AccessController.doPrivileged(pa); }