From f5b63e9852b5eecdb34e925afa3d64172395967f Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Wed, 31 Jan 2018 15:15:09 -0800 Subject: [PATCH] 8196310: jlink --suggest-providers fails with missing resource if --output specified Reviewed-by: alanb, lancea, sundar --- .../jdk/tools/jlink/internal/JlinkTask.java | 21 ++++++++----------- .../tools/jlink/resources/jlink.properties | 2 +- 2 files changed, 10 insertions(+), 13 deletions(-) diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java index 72d512f2c25..beba588a8c2 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java @@ -43,8 +43,6 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.util.ArrayList; import java.util.Arrays; -import java.util.Collection; -import java.util.Collections; import java.util.Comparator; import java.util.Date; import java.util.HashMap; @@ -231,7 +229,8 @@ public class JlinkTask { try { List remaining = optionsHelper.handleOptions(this, args); if (remaining.size() > 0 && !options.suggestProviders) { - throw taskHelper.newBadArgs("err.orphan.arguments", toString(remaining)) + throw taskHelper.newBadArgs("err.orphan.arguments", + remaining.stream().collect(Collectors.joining(" "))) .showUsage(true); } if (options.help) { @@ -659,9 +658,12 @@ public class JlinkTask { throws BadArgs { if (args.size() > 1) { - throw taskHelper.newBadArgs("err.orphan.argument", - toString(args.subList(1, args.size()))) - .showUsage(true); + List arguments = args.get(0).startsWith("-") + ? args + : args.subList(1, args.size()); + throw taskHelper.newBadArgs("err.invalid.arg.for.option", + "--suggest-providers", + arguments.stream().collect(Collectors.joining(" "))); } if (options.bindServices) { @@ -714,7 +716,7 @@ public class JlinkTask { .forEach(names::remove); if (!names.isEmpty()) { log.println(taskHelper.getMessage("warn.provider.notfound", - toString(names))); + names.stream().sorted().collect(Collectors.joining(",")))); } String msg = String.format("%n%s:", taskHelper.getMessage("suggested.providers.header")); @@ -722,11 +724,6 @@ public class JlinkTask { } } - private static String toString(Collection collection) { - return collection.stream().sorted() - .collect(Collectors.joining(",")); - } - private String getSaveOpts() { StringBuilder sb = new StringBuilder(); sb.append('#').append(new Date()).append("\n"); diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink.properties b/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink.properties index f7c99cfc6f6..0353896d660 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink.properties +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink.properties @@ -128,7 +128,7 @@ err.badpattern=bad pattern {0} err.unknown.option=unknown option: {0} err.missing.arg=no value given for {0} err.internal.error=internal error: {0} {1} {2} -err.invalid.arg.for.option=invalid argument for option: {0} +err.invalid.arg.for.option={0} does not accept \"{1}\" argument err.option.after.class=option must be specified before classes: {0} err.option.unsupported={0} not supported: {1} err.orphan.arguments=invalid argument: {0}