From 15ec4ba5c62a64fbd82bbaa7649efd7e6e277b8e Mon Sep 17 00:00:00 2001 From: Severin Gehwolf Date: Wed, 13 Feb 2019 12:01:09 +0100 Subject: [PATCH] 8218913: Rename --strip-debug jlink plugin Reviewed-by: alanb, mchung --- .../jdk/tools/jlink/internal/TaskHelper.java | 4 +- .../plugins/DefaultStripDebugPlugin.java | 58 +++++++++++++++++++ ...va => StripJavaDebugAttributesPlugin.java} | 13 +++-- .../tools/jlink/resources/plugins.properties | 3 + src/jdk.jlink/share/classes/module-info.java | 3 +- test/jdk/tools/jlink/IntegrationTest.java | 4 +- ...> StripJavaDebugAttributesPluginTest.java} | 20 +++---- 7 files changed, 84 insertions(+), 21 deletions(-) create mode 100644 src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultStripDebugPlugin.java rename src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/{StripDebugPlugin.java => StripJavaDebugAttributesPlugin.java} (91%) rename test/jdk/tools/jlink/plugins/{StripDebugPluginTest.java => StripJavaDebugAttributesPluginTest.java} (94%) diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java index 2df4afc1a4a..717ac408614 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java @@ -49,9 +49,9 @@ import jdk.tools.jlink.builder.DefaultImageBuilder; import jdk.tools.jlink.builder.ImageBuilder; import jdk.tools.jlink.internal.Jlink.PluginsConfiguration; import jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; +import jdk.tools.jlink.internal.plugins.DefaultStripDebugPlugin; import jdk.tools.jlink.internal.plugins.ExcludeJmodSectionPlugin; import jdk.tools.jlink.internal.plugins.PluginsResourceBundle; -import jdk.tools.jlink.internal.plugins.StripDebugPlugin; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.Plugin.Category; import jdk.tools.jlink.plugin.PluginException; @@ -375,7 +375,7 @@ public final class TaskHelper { m.put(DefaultCompressPlugin.NAME, DefaultCompressPlugin.LEVEL_2); }, false, "--compress", "-c"); mainOptions.add(plugOption); - } else if (plugin instanceof StripDebugPlugin) { + } else if (plugin instanceof DefaultStripDebugPlugin) { plugOption = new PluginOption(false, (task, opt, arg) -> { diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultStripDebugPlugin.java b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultStripDebugPlugin.java new file mode 100644 index 00000000000..1195e82c4d1 --- /dev/null +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultStripDebugPlugin.java @@ -0,0 +1,58 @@ +/* + * Copyright (c) 2019, Red Hat, Inc. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package jdk.tools.jlink.internal.plugins; + +import jdk.tools.jlink.plugin.Plugin; +import jdk.tools.jlink.plugin.ResourcePool; +import jdk.tools.jlink.plugin.ResourcePoolBuilder; + +/** + * Combined debug stripping plugin: Java debug attributes and native debug + * symbols. + * + */ +public final class DefaultStripDebugPlugin implements Plugin { + + public static final String NAME = "strip-debug"; + + private final Plugin javaStripPlugin = new StripJavaDebugAttributesPlugin(); + + @Override + public String getName() { + return NAME; + } + + @Override + public String getDescription() { + return PluginsResourceBundle.getDescription(NAME); + } + + @Override + public ResourcePool transform(ResourcePool in, ResourcePoolBuilder out) { + return javaStripPlugin.transform(in, out); + } + +} diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripJavaDebugAttributesPlugin.java similarity index 91% rename from src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java rename to src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripJavaDebugAttributesPlugin.java index 085ba5f28a5..4ed09aedbbe 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripJavaDebugAttributesPlugin.java @@ -25,26 +25,27 @@ package jdk.tools.jlink.internal.plugins; import java.util.function.Predicate; + import jdk.internal.org.objectweb.asm.ClassReader; import jdk.internal.org.objectweb.asm.ClassWriter; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ResourcePool; import jdk.tools.jlink.plugin.ResourcePoolBuilder; import jdk.tools.jlink.plugin.ResourcePoolEntry; -import jdk.tools.jlink.plugin.Plugin; /** * - * Strip debug attributes plugin + * Strip java debug attributes plugin */ -public final class StripDebugPlugin implements Plugin { - public static final String NAME = "strip-debug"; +public final class StripJavaDebugAttributesPlugin implements Plugin { + public static final String NAME = "strip-java-debug-attributes"; private final Predicate predicate; - public StripDebugPlugin() { + public StripJavaDebugAttributesPlugin() { this((path) -> false); } - StripDebugPlugin(Predicate predicate) { + StripJavaDebugAttributesPlugin(Predicate predicate) { this.predicate = predicate; } diff --git a/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties b/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties index 72815fc5be0..8724b63c3cc 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties +++ b/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties @@ -99,6 +99,9 @@ Order resources. e.g.: **/module-info.class,@classlist,/java.base/java/lang/** strip-debug.description=\ Strip debug information from the output image +strip-java-debug-attributes.description=\ +Strip Java debug attributes from classes in the output image + strip-native-commands.description=\ Exclude native commands (such as java/java.exe) from the image diff --git a/src/jdk.jlink/share/classes/module-info.java b/src/jdk.jlink/share/classes/module-info.java index e4fac05cfad..bbb0b785037 100644 --- a/src/jdk.jlink/share/classes/module-info.java +++ b/src/jdk.jlink/share/classes/module-info.java @@ -63,7 +63,8 @@ module jdk.jlink { jdk.tools.jlink.internal.Main.JlinkToolProvider; provides jdk.tools.jlink.plugin.Plugin with - jdk.tools.jlink.internal.plugins.StripDebugPlugin, + jdk.tools.jlink.internal.plugins.DefaultStripDebugPlugin, + jdk.tools.jlink.internal.plugins.StripJavaDebugAttributesPlugin, jdk.tools.jlink.internal.plugins.ExcludePlugin, jdk.tools.jlink.internal.plugins.ExcludeFilesPlugin, jdk.tools.jlink.internal.plugins.ExcludeJmodSectionPlugin, diff --git a/test/jdk/tools/jlink/IntegrationTest.java b/test/jdk/tools/jlink/IntegrationTest.java index bf23080bce2..73aa129be3d 100644 --- a/test/jdk/tools/jlink/IntegrationTest.java +++ b/test/jdk/tools/jlink/IntegrationTest.java @@ -49,7 +49,7 @@ import jdk.tools.jlink.internal.Jlink.JlinkConfiguration; import jdk.tools.jlink.internal.Jlink.PluginsConfiguration; import jdk.tools.jlink.internal.PostProcessor; import jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; -import jdk.tools.jlink.internal.plugins.StripDebugPlugin; +import jdk.tools.jlink.internal.plugins.DefaultStripDebugPlugin; import tests.Helper; import tests.JImageGenerator; @@ -168,7 +168,7 @@ public class IntegrationTest { //Strip debug { Map config1 = new HashMap<>(); - config1.put(StripDebugPlugin.NAME, ""); + config1.put(DefaultStripDebugPlugin.NAME, ""); Plugin strip = Jlink.newPlugin("strip-debug", config1, null); lst.add(strip); } diff --git a/test/jdk/tools/jlink/plugins/StripDebugPluginTest.java b/test/jdk/tools/jlink/plugins/StripJavaDebugAttributesPluginTest.java similarity index 94% rename from test/jdk/tools/jlink/plugins/StripDebugPluginTest.java rename to test/jdk/tools/jlink/plugins/StripJavaDebugAttributesPluginTest.java index 4835bbe6097..8d081d25dc4 100644 --- a/test/jdk/tools/jlink/plugins/StripDebugPluginTest.java +++ b/test/jdk/tools/jlink/plugins/StripJavaDebugAttributesPluginTest.java @@ -23,7 +23,7 @@ /* * @test - * @summary Test StripDebugPlugin + * @summary Test StripJavaDebugAttributesPlugin * @author Jean-Francois Denise * @library ../../lib * @build tests.* @@ -35,7 +35,7 @@ * jdk.jlink/jdk.tools.jmod * jdk.jdeps/com.sun.tools.classfile * jdk.compiler - * @run main StripDebugPluginTest + * @run main StripJavaDebugAttributesPluginTest */ import java.io.ByteArrayInputStream; @@ -44,6 +44,7 @@ import java.nio.file.Files; import java.nio.file.Path; import java.util.ArrayList; import java.util.Arrays; +import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.stream.Stream; @@ -53,18 +54,17 @@ import com.sun.tools.classfile.ClassFile; import com.sun.tools.classfile.Code_attribute; import com.sun.tools.classfile.ConstantPoolException; import com.sun.tools.classfile.Method; -import java.util.HashMap; -import java.util.Map; + import jdk.tools.jlink.internal.ResourcePoolManager; -import jdk.tools.jlink.internal.plugins.StripDebugPlugin; -import jdk.tools.jlink.plugin.ResourcePoolEntry; -import jdk.tools.jlink.plugin.ResourcePool; +import jdk.tools.jlink.internal.plugins.StripJavaDebugAttributesPlugin; import jdk.tools.jlink.plugin.Plugin; +import jdk.tools.jlink.plugin.ResourcePool; +import jdk.tools.jlink.plugin.ResourcePoolEntry; import tests.Helper; -public class StripDebugPluginTest { +public class StripJavaDebugAttributesPluginTest { public static void main(String[] args) throws Exception { - new StripDebugPluginTest().test(); + new StripJavaDebugAttributesPluginTest().test(); } public void test() throws Exception { @@ -105,7 +105,7 @@ public class StripDebugPluginTest { private void check(String path, byte[] content, String infoPath, byte[] moduleInfo) throws Exception { path = path.replace('\\', '/'); - StripDebugPlugin debug = new StripDebugPlugin(); + StripJavaDebugAttributesPlugin debug = new StripJavaDebugAttributesPlugin(); debug.configure(new HashMap<>()); ResourcePoolEntry result1 = stripDebug(debug, ResourcePoolEntry.create(path,content), path, infoPath, moduleInfo);