From 81d15be0dbbf0da3a527f93c67077e82861bebb2 Mon Sep 17 00:00:00 2001 From: Valerie Peng Date: Tue, 11 Oct 2016 00:04:35 +0000 Subject: [PATCH 01/43] 8165275: Replace the reflective call to the implUpdate method in HandshakeMessage::digestKey Replaced the reflection calls with the new sun.security.util.MessageDigestSpi2 interface Reviewed-by: xuelei, mchung --- .../classes/java/security/MessageDigest.java | 15 ++++- .../sun/security/ssl/HandshakeMessage.java | 56 ++----------------- .../sun/security/util/MessageDigestSpi2.java | 44 +++++++++++++++ .../sun/security/pkcs11/P11Digest.java | 16 ++++-- 4 files changed, 71 insertions(+), 60 deletions(-) create mode 100644 jdk/src/java.base/share/classes/sun/security/util/MessageDigestSpi2.java diff --git a/jdk/src/java.base/share/classes/java/security/MessageDigest.java b/jdk/src/java.base/share/classes/java/security/MessageDigest.java index 3c08a64fbf8..b6959f5db4f 100644 --- a/jdk/src/java.base/share/classes/java/security/MessageDigest.java +++ b/jdk/src/java.base/share/classes/java/security/MessageDigest.java @@ -32,10 +32,13 @@ import java.io.ByteArrayOutputStream; import java.io.PrintStream; import java.io.InputStream; import java.io.ByteArrayInputStream; - +import java.security.InvalidKeyException; import java.nio.ByteBuffer; import sun.security.util.Debug; +import sun.security.util.MessageDigestSpi2; + +import javax.crypto.SecretKey; /** * This MessageDigest class provides applications the functionality of a @@ -548,7 +551,7 @@ public abstract class MessageDigest extends MessageDigestSpi { * and its original parent (Object). */ - static class Delegate extends MessageDigest { + static class Delegate extends MessageDigest implements MessageDigestSpi2 { // The provider implementation (delegate) private MessageDigestSpi digestSpi; @@ -601,6 +604,14 @@ public abstract class MessageDigest extends MessageDigestSpi { digestSpi.engineUpdate(input); } + public void engineUpdate(SecretKey key) throws InvalidKeyException { + if (digestSpi instanceof MessageDigestSpi2) { + ((MessageDigestSpi2)digestSpi).engineUpdate(key); + } else { + throw new UnsupportedOperationException + ("Digest does not support update of SecretKey object"); + } + } protected byte[] engineDigest() { return digestSpi.engineDigest(); } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java b/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java index b3740cfcd86..4717fbba178 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java @@ -49,6 +49,7 @@ import sun.security.internal.spec.TlsPrfParameterSpec; import sun.security.ssl.CipherSuite.*; import static sun.security.ssl.CipherSuite.PRF.*; import sun.security.util.KeyUtil; +import sun.security.util.MessageDigestSpi2; import sun.security.provider.certpath.OCSPResponse; /** @@ -2124,63 +2125,14 @@ static final class CertificateVerify extends HandshakeMessage { md.update(temp); } - private static final Class delegate; - private static final Field spiField; - - static { - try { - delegate = Class.forName("java.security.MessageDigest$Delegate"); - spiField = delegate.getDeclaredField("digestSpi"); - } catch (Exception e) { - throw new RuntimeException("Reflection failed", e); - } - makeAccessible(spiField); - } - - private static void makeAccessible(final AccessibleObject o) { - AccessController.doPrivileged(new PrivilegedAction() { - @Override - public Object run() { - o.setAccessible(true); - return null; - } - }); - } - - // ConcurrentHashMap does not allow null values, use this marker object - private static final Object NULL_OBJECT = new Object(); - - // cache Method objects per Spi class - // Note that this will prevent the Spi classes from being GC'd. We assume - // that is not a problem. - private static final Map,Object> methodCache = - new ConcurrentHashMap<>(); - private static void digestKey(MessageDigest md, SecretKey key) { try { - // Verify that md is implemented via MessageDigestSpi, not - // via JDK 1.1 style MessageDigest subclassing. - if (md.getClass() != delegate) { - throw new Exception("Digest is not a MessageDigestSpi"); - } - MessageDigestSpi spi = (MessageDigestSpi)spiField.get(md); - Class clazz = spi.getClass(); - Object r = methodCache.get(clazz); - if (r == null) { - try { - r = clazz.getDeclaredMethod("implUpdate", SecretKey.class); - makeAccessible((Method)r); - } catch (NoSuchMethodException e) { - r = NULL_OBJECT; - } - methodCache.put(clazz, r); - } - if (r == NULL_OBJECT) { + if (md instanceof MessageDigestSpi2) { + ((MessageDigestSpi2)md).engineUpdate(key); + } else { throw new Exception( "Digest does not support implUpdate(SecretKey)"); } - Method update = (Method)r; - update.invoke(spi, key); } catch (Exception e) { throw new RuntimeException( "Could not obtain encoded key and " diff --git a/jdk/src/java.base/share/classes/sun/security/util/MessageDigestSpi2.java b/jdk/src/java.base/share/classes/sun/security/util/MessageDigestSpi2.java new file mode 100644 index 00000000000..4fbf285a8a2 --- /dev/null +++ b/jdk/src/java.base/share/classes/sun/security/util/MessageDigestSpi2.java @@ -0,0 +1,44 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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 sun.security.util; + +import java.security.InvalidKeyException; +import javax.crypto.SecretKey; + +/** + * Special interface for additional MessageDigestSpi method(s). + */ +public interface MessageDigestSpi2 { + + /** + * Updates the digest using the specified key. + * This is used for SSL 3.0 only, we may deprecate and remove the support + * of this in the future + * + * @param key the key whose value is to be digested. + */ + void engineUpdate(SecretKey key) throws InvalidKeyException; +} diff --git a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Digest.java b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Digest.java index 2dc66d2368b..c82e44b219f 100644 --- a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Digest.java +++ b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Digest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,6 +34,8 @@ import javax.crypto.SecretKey; import sun.nio.ch.DirectBuffer; +import sun.security.util.MessageDigestSpi2; + import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; @@ -49,7 +51,8 @@ import static sun.security.pkcs11.wrapper.PKCS11Constants.*; * @author Andreas Sterbenz * @since 1.5 */ -final class P11Digest extends MessageDigestSpi implements Cloneable { +final class P11Digest extends MessageDigestSpi implements Cloneable, + MessageDigestSpi2 { /* fields initialized, no session acquired */ private final static int S_BLANK = 1; @@ -233,10 +236,11 @@ final class P11Digest extends MessageDigestSpi implements Cloneable { } // Called by SunJSSE via reflection during the SSL 3.0 handshake if - // the master secret is sensitive. We may want to consider making this - // method public in a future release. - protected void implUpdate(SecretKey key) throws InvalidKeyException { - + // the master secret is sensitive. + // Note: Change to protected after this method is moved from + // sun.security.util.MessageSpi2 interface to + // java.security.MessageDigestSpi class + public void engineUpdate(SecretKey key) throws InvalidKeyException { // SunJSSE calls this method only if the key does not have a RAW // encoding, i.e. if it is sensitive. Therefore, no point in calling // SecretKeyFactory to try to convert it. Just verify it ourselves. From 3e6227e27fad52c83e75708b915d7028832b37e5 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 09:49:31 +0200 Subject: [PATCH 02/43] 8167424: Various trivial fixes in build system Reviewed-by: erikj, tbell --- common/autoconf/basics_windows.m4 | 2 +- common/autoconf/boot-jdk.m4 | 2 +- common/autoconf/bootcycle-spec.gmk.in | 2 +- common/autoconf/buildjdk-spec.gmk.in | 6 +----- common/autoconf/compare.sh.in | 2 +- common/autoconf/generated-configure.sh | 26 +++++++++++++++++++------- common/autoconf/jdk-version.m4 | 2 +- common/autoconf/lib-bundled.m4 | 2 +- common/autoconf/source-dirs.m4 | 2 +- common/autoconf/spec.gmk.in | 5 +---- common/autoconf/version-numbers | 2 +- common/bin/compare_exceptions.sh.incl | 2 +- common/bin/hgforest.sh | 2 +- common/bin/jib.sh | 2 +- common/conf/jib-profiles.js | 2 +- make/CopyImportModules.gmk | 4 ++-- make/CreateBuildJdkCopy.gmk | 2 +- make/GensrcModuleInfo.gmk | 2 +- make/Images.gmk | 2 +- make/Init.gmk | 2 +- make/InitSupport.gmk | 2 +- make/Jprt.gmk | 2 +- make/JrtfsJar.gmk | 6 +++--- make/MacBundles.gmk | 2 +- make/Main.gmk | 2 +- make/common/CORE_PKGS.gmk | 2 +- make/common/JavaCompilation.gmk | 2 +- make/common/NON_CORE_PKGS.gmk | 2 +- make/common/SetupJavaCompilers.gmk | 2 +- make/devkit/Tools.gmk | 2 +- make/devkit/createWindowsDevkit.sh | 2 +- 31 files changed, 52 insertions(+), 47 deletions(-) diff --git a/common/autoconf/basics_windows.m4 b/common/autoconf/basics_windows.m4 index 52aea899351..1a79bf8fc86 100644 --- a/common/autoconf/basics_windows.m4 +++ b/common/autoconf/basics_windows.m4 @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/boot-jdk.m4 b/common/autoconf/boot-jdk.m4 index 83ec28e39bb..ab2bd9a87d7 100644 --- a/common/autoconf/boot-jdk.m4 +++ b/common/autoconf/boot-jdk.m4 @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/bootcycle-spec.gmk.in b/common/autoconf/bootcycle-spec.gmk.in index 3c9c1dbe23b..e26450ae3fc 100644 --- a/common/autoconf/bootcycle-spec.gmk.in +++ b/common/autoconf/bootcycle-spec.gmk.in @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/buildjdk-spec.gmk.in b/common/autoconf/buildjdk-spec.gmk.in index a643d82e45b..dba07605a22 100644 --- a/common/autoconf/buildjdk-spec.gmk.in +++ b/common/autoconf/buildjdk-spec.gmk.in @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -156,7 +156,3 @@ JVM_VARIANT_KERNEL := false JVM_VARIANT_ZERO := false JVM_VARIANT_ZEROSHARK := false JVM_VARIANT_CORE := false - -# Sneak this in via the spec.gmk file, since we don't want to mess around too much with the Hotspot make files. -# This is needed to get the LOG setting to work properly. -include $(SRC_ROOT)/make/common/MakeBase.gmk diff --git a/common/autoconf/compare.sh.in b/common/autoconf/compare.sh.in index f7e2003ca32..44933806256 100644 --- a/common/autoconf/compare.sh.in +++ b/common/autoconf/compare.sh.in @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 48b23344af8..6d6b0a5b5ce 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -1111,6 +1111,7 @@ infodir docdir oldincludedir includedir +runstatedir localstatedir sharedstatedir sysconfdir @@ -1389,6 +1390,7 @@ datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' +runstatedir='${localstatedir}/run' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' @@ -1641,6 +1643,15 @@ do | -silent | --silent | --silen | --sile | --sil) silent=yes ;; + -runstatedir | --runstatedir | --runstatedi | --runstated \ + | --runstate | --runstat | --runsta | --runst | --runs \ + | --run | --ru | --r) + ac_prev=runstatedir ;; + -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \ + | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \ + | --run=* | --ru=* | --r=*) + runstatedir=$ac_optarg ;; + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ @@ -1778,7 +1789,7 @@ fi for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ - libdir localedir mandir + libdir localedir mandir runstatedir do eval ac_val=\$$ac_var # Remove trailing slashes. @@ -1931,6 +1942,7 @@ Fine tuning of the installation directories: --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] + --runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] @@ -3733,7 +3745,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # -# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -3792,7 +3804,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # ... then the rest # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -4403,7 +4415,7 @@ VALID_JVM_VARIANTS="server client minimal core zero zeroshark custom" # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -4498,7 +4510,7 @@ VALID_JVM_VARIANTS="server client minimal core zero zeroshark custom" # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -4818,7 +4830,7 @@ VALID_JVM_VARIANTS="server client minimal core zero zeroshark custom" # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -5091,7 +5103,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1475218974 +DATE_WHEN_GENERATED=1476172133 ############################################################################### # diff --git a/common/autoconf/jdk-version.m4 b/common/autoconf/jdk-version.m4 index 3b2fbfb60f1..4846c12647c 100644 --- a/common/autoconf/jdk-version.m4 +++ b/common/autoconf/jdk-version.m4 @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/lib-bundled.m4 b/common/autoconf/lib-bundled.m4 index 9c8ad722fd8..218d3f87adf 100644 --- a/common/autoconf/lib-bundled.m4 +++ b/common/autoconf/lib-bundled.m4 @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/source-dirs.m4 b/common/autoconf/source-dirs.m4 index fa2f74d2237..940707e81a0 100644 --- a/common/autoconf/source-dirs.m4 +++ b/common/autoconf/source-dirs.m4 @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/autoconf/spec.gmk.in b/common/autoconf/spec.gmk.in index 710cf70ab7c..7725e6fe84c 100644 --- a/common/autoconf/spec.gmk.in +++ b/common/autoconf/spec.gmk.in @@ -175,7 +175,7 @@ VERSION_NUMBER_FOUR_POSITIONS := @VERSION_NUMBER_FOUR_POSITIONS@ VERSION_STRING := @VERSION_STRING@ # The short version string, without trailing zeroes and just PRE, if present. VERSION_SHORT := @VERSION_SHORT@ -# The Java specification version. It usually equals to the major version number. +# The Java specification version. It usually equals the major version number. VERSION_SPECIFICATION := @VERSION_MAJOR@ # A GA version is defined by the PRE string being empty. Rather than testing for # that, this variable defines it with true/false. @@ -244,9 +244,6 @@ USE_PRECOMPILED_HEADER := @USE_PRECOMPILED_HEADER@ # Only build headless support or not ENABLE_HEADLESS_ONLY := @ENABLE_HEADLESS_ONLY@ -# Legacy support -USE_NEW_HOTSPOT_BUILD:=@USE_NEW_HOTSPOT_BUILD@ - # JDK_OUTPUTDIR specifies where a working jvm is built. # You can run $(JDK_OUTPUTDIR)/bin/java # Though the layout of the contents of $(JDK_OUTPUTDIR) is not diff --git a/common/autoconf/version-numbers b/common/autoconf/version-numbers index 98f106680b5..ac2c9f24655 100644 --- a/common/autoconf/version-numbers +++ b/common/autoconf/version-numbers @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/bin/compare_exceptions.sh.incl b/common/bin/compare_exceptions.sh.incl index 7b76ab37029..a4c4278299a 100644 --- a/common/bin/compare_exceptions.sh.incl +++ b/common/bin/compare_exceptions.sh.incl @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/bin/hgforest.sh b/common/bin/hgforest.sh index 7320aa09a11..3007d3e8860 100644 --- a/common/bin/hgforest.sh +++ b/common/bin/hgforest.sh @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2009, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/bin/jib.sh b/common/bin/jib.sh index ea52385537b..ceac118bb77 100644 --- a/common/bin/jib.sh +++ b/common/bin/jib.sh @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/common/conf/jib-profiles.js b/common/conf/jib-profiles.js index d003e1815e4..a9f3d8d0289 100644 --- a/common/conf/jib-profiles.js +++ b/common/conf/jib-profiles.js @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/make/CopyImportModules.gmk b/make/CopyImportModules.gmk index c1518457bbc..ee0de88ee84 100644 --- a/make/CopyImportModules.gmk +++ b/make/CopyImportModules.gmk @@ -41,14 +41,14 @@ ifneq ($(LIBS_DIR), ) ifeq ($(OPENJDK_TARGET_OS), windows) TO_BIN_FILTER := %$(SHARED_LIBRARY_SUFFIX) %.diz %.pdb %.map - $(eval $(call SetupCopyFiles,COPY_LIBS_TO_BIN, \ + $(eval $(call SetupCopyFiles, COPY_LIBS_TO_BIN, \ SRC := $(LIBS_DIR), \ DEST := $(JDK_OUTPUTDIR)/bin, \ FILES := $(filter $(TO_BIN_FILTER), \ $(call CacheFind, $(LIBS_DIR))) \ )) - $(eval $(call SetupCopyFiles,COPY_LIBS_TO_LIB, \ + $(eval $(call SetupCopyFiles, COPY_LIBS_TO_LIB, \ SRC := $(LIBS_DIR), \ DEST := $(JDK_OUTPUTDIR)/lib, \ FILES := $(filter-out $(TO_BIN_FILTER), \ diff --git a/make/CreateBuildJdkCopy.gmk b/make/CreateBuildJdkCopy.gmk index 0a9ba2c4789..6e28a2df95f 100644 --- a/make/CreateBuildJdkCopy.gmk +++ b/make/CreateBuildJdkCopy.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/GensrcModuleInfo.gmk b/make/GensrcModuleInfo.gmk index 79704ce020a..cd0c3af9f00 100644 --- a/make/GensrcModuleInfo.gmk +++ b/make/GensrcModuleInfo.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/Images.gmk b/make/Images.gmk index e2fd56ca597..fac10d51475 100644 --- a/make/Images.gmk +++ b/make/Images.gmk @@ -412,7 +412,7 @@ endif ################################################################################ # /sample dir -$(eval $(call SetupCopyFiles,COPY_SAMPLES, \ +$(eval $(call SetupCopyFiles, COPY_SAMPLES, \ SRC := $(SUPPORT_OUTPUTDIR)/sample/image, \ DEST := $(JDK_IMAGE_DIR)/sample, \ FILES := $(if $(wildcard $(SUPPORT_OUTPUTDIR)/sample/image), \ diff --git a/make/Init.gmk b/make/Init.gmk index 15ae487555c..2e391a4e199 100644 --- a/make/Init.gmk +++ b/make/Init.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/InitSupport.gmk b/make/InitSupport.gmk index cee30522d33..77ee2d0da92 100644 --- a/make/InitSupport.gmk +++ b/make/InitSupport.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/Jprt.gmk b/make/Jprt.gmk index 09d6dc7ef7b..411525a143b 100644 --- a/make/Jprt.gmk +++ b/make/Jprt.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/JrtfsJar.gmk b/make/JrtfsJar.gmk index ce5d5bea6c3..36ba0beba2b 100644 --- a/make/JrtfsJar.gmk +++ b/make/JrtfsJar.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -46,7 +46,7 @@ JIMAGE_PKGS := \ jdk/internal/jrtfs \ # -$(eval $(call SetupJavaCompilation,BUILD_JRTFS, \ +$(eval $(call SetupJavaCompilation, BUILD_JRTFS, \ SETUP := GENERATE_OLDBYTECODE, \ SRC := $(JDK_TOPDIR)/src/java.base/share/classes, \ EXCLUDE_FILES := module-info.java, \ @@ -57,7 +57,7 @@ $(eval $(call SetupJavaCompilation,BUILD_JRTFS, \ # file will not be copied unless META-INF/services would also be added to the INCLUDES. # Adding META-INF/services would include all files in that directory when only the one # is needed, which is why this explicit copy is defined instead. -$(eval $(call SetupCopyFiles,COPY_JIMAGE_SERVICE_PROVIDER, \ +$(eval $(call SetupCopyFiles, COPY_JIMAGE_SERVICE_PROVIDER, \ SRC := $(JDK_TOPDIR)/src/java.base/share/classes, \ DEST := $(SUPPORT_OUTPUTDIR)/jrtfs_classes, \ FILES := META-INF/services/java.nio.file.spi.FileSystemProvider)) diff --git a/make/MacBundles.gmk b/make/MacBundles.gmk index f860e5e074a..a4e7db333db 100644 --- a/make/MacBundles.gmk +++ b/make/MacBundles.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/Main.gmk b/make/Main.gmk index c3b518a860d..44c8c192172 100644 --- a/make/Main.gmk +++ b/make/Main.gmk @@ -237,7 +237,7 @@ ALL_TARGETS += $(LAUNCHER_TARGETS) # Build hotspot target ifeq ($(BUILD_HOTSPOT),true) -hotspot: + hotspot: +($(CD) $(HOTSPOT_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f BuildHotspot.gmk) endif diff --git a/make/common/CORE_PKGS.gmk b/make/common/CORE_PKGS.gmk index 3223460f098..96c77123372 100644 --- a/make/common/CORE_PKGS.gmk +++ b/make/common/CORE_PKGS.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/common/JavaCompilation.gmk b/make/common/JavaCompilation.gmk index 34c82fdef41..9220865a534 100644 --- a/make/common/JavaCompilation.gmk +++ b/make/common/JavaCompilation.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/common/NON_CORE_PKGS.gmk b/make/common/NON_CORE_PKGS.gmk index e17ff1402ea..26a387a5e90 100644 --- a/make/common/NON_CORE_PKGS.gmk +++ b/make/common/NON_CORE_PKGS.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/common/SetupJavaCompilers.gmk b/make/common/SetupJavaCompilers.gmk index fe54cff3d4e..77da1e6f6a5 100644 --- a/make/common/SetupJavaCompilers.gmk +++ b/make/common/SetupJavaCompilers.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/devkit/Tools.gmk b/make/devkit/Tools.gmk index 5c5a05e0006..32a79caffbe 100644 --- a/make/devkit/Tools.gmk +++ b/make/devkit/Tools.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/make/devkit/createWindowsDevkit.sh b/make/devkit/createWindowsDevkit.sh index fd007a01a9b..67d29bd7c9f 100644 --- a/make/devkit/createWindowsDevkit.sh +++ b/make/devkit/createWindowsDevkit.sh @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it From f098b9348244f96eb8084451d2258f24dd2bcb15 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 09:49:43 +0200 Subject: [PATCH 03/43] 8167424: Various trivial fixes in build system Reviewed-by: erikj, tbell --- nashorn/make/BuildNashorn.gmk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/nashorn/make/BuildNashorn.gmk b/nashorn/make/BuildNashorn.gmk index 3ff22e00e3b..fd11bd6e9db 100644 --- a/nashorn/make/BuildNashorn.gmk +++ b/nashorn/make/BuildNashorn.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2010, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it From a6aec9bc101630cc28dacd202acd7e989cf58f9c Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 09:49:50 +0200 Subject: [PATCH 04/43] 8167424: Various trivial fixes in build system Reviewed-by: erikj, tbell --- hotspot/make/lib/CompileGtest.gmk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/make/lib/CompileGtest.gmk b/hotspot/make/lib/CompileGtest.gmk index 1f7c317a427..9c69a2f175a 100644 --- a/hotspot/make/lib/CompileGtest.gmk +++ b/hotspot/make/lib/CompileGtest.gmk @@ -69,7 +69,7 @@ $(eval $(call SetupNativeCompilation, BUILD_GTEST_LIBJVM, \ CFLAGS := $(JVM_CFLAGS) -I$(GTEST_FRAMEWORK_SRC) \ -I$(GTEST_FRAMEWORK_SRC)/include \ $(addprefix -I,$(GTEST_TEST_SRC)), \ - CFLAGS_windows := /EHsc, \ + CFLAGS_windows := -EHsc, \ CFLAGS_solaris := -DGTEST_HAS_EXCEPTIONS=0 -library=stlport4, \ CFLAGS_macosx := -DGTEST_OS_MAC=1, \ CFLAGS_DEBUG_SYMBOLS := $(JVM_CFLAGS_SYMBOLS), \ From 46cb0861d001b3e656b3fb7a4a1cd930c155f474 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 09:50:04 +0200 Subject: [PATCH 05/43] 8167424: Various trivial fixes in build system Reviewed-by: erikj, tbell --- jdk/make/CompileInterimRmic.gmk | 2 +- jdk/make/CompileTools.gmk | 2 +- jdk/make/GenerateModuleSummary.gmk | 2 +- jdk/make/Tools.gmk | 2 +- jdk/make/gendata/GendataBreakIterator.gmk | 2 +- jdk/make/gendata/GendataHtml32dtd.gmk | 2 +- jdk/make/gensrc/Gensrc-java.base.gmk | 2 +- jdk/make/gensrc/Gensrc-jdk.jlink.gmk | 2 +- jdk/make/gensrc/GensrcIcons.gmk | 2 +- jdk/make/gensrc/GensrcLocaleData.gmk | 2 +- jdk/make/gensrc/GensrcModuleLoaderMap.gmk | 2 +- jdk/make/gensrc/GensrcVarHandles.gmk | 2 +- jdk/make/launcher/Launcher-java.scripting.gmk | 2 +- jdk/make/launcher/Launcher-jdk.compiler.gmk | 2 +- jdk/make/launcher/Launcher-jdk.javadoc.gmk | 2 +- jdk/make/launcher/Launcher-jdk.jdeps.gmk | 2 +- jdk/make/launcher/Launcher-jdk.jlink.gmk | 2 +- jdk/make/launcher/Launcher-jdk.jstatd.gmk | 2 +- jdk/make/launcher/Launcher-jdk.pack200.gmk | 2 +- jdk/make/launcher/Launcher-jdk.scripting.nashorn.shell.gmk | 2 +- jdk/make/lib/Lib-java.desktop.gmk | 2 +- jdk/make/rmic/Rmic-java.management.gmk | 2 +- jdk/make/rmic/RmicCommon.gmk | 2 +- 23 files changed, 23 insertions(+), 23 deletions(-) diff --git a/jdk/make/CompileInterimRmic.gmk b/jdk/make/CompileInterimRmic.gmk index ce60127e6d1..9a30893f142 100644 --- a/jdk/make/CompileInterimRmic.gmk +++ b/jdk/make/CompileInterimRmic.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/CompileTools.gmk b/jdk/make/CompileTools.gmk index 46dab28f146..9d76d660e2d 100644 --- a/jdk/make/CompileTools.gmk +++ b/jdk/make/CompileTools.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/GenerateModuleSummary.gmk b/jdk/make/GenerateModuleSummary.gmk index 171183886a2..38d9985c263 100644 --- a/jdk/make/GenerateModuleSummary.gmk +++ b/jdk/make/GenerateModuleSummary.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/Tools.gmk b/jdk/make/Tools.gmk index 1034d34e15b..92af1ee102f 100644 --- a/jdk/make/Tools.gmk +++ b/jdk/make/Tools.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gendata/GendataBreakIterator.gmk b/jdk/make/gendata/GendataBreakIterator.gmk index 2f7f5dff981..828e6314790 100644 --- a/jdk/make/gendata/GendataBreakIterator.gmk +++ b/jdk/make/gendata/GendataBreakIterator.gmk @@ -1,5 +1,5 @@ -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gendata/GendataHtml32dtd.gmk b/jdk/make/gendata/GendataHtml32dtd.gmk index 0c18d2a280c..0189a7c081e 100644 --- a/jdk/make/gendata/GendataHtml32dtd.gmk +++ b/jdk/make/gendata/GendataHtml32dtd.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/Gensrc-java.base.gmk b/jdk/make/gensrc/Gensrc-java.base.gmk index 66e41feb5e1..2a28382858e 100644 --- a/jdk/make/gensrc/Gensrc-java.base.gmk +++ b/jdk/make/gensrc/Gensrc-java.base.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/Gensrc-jdk.jlink.gmk b/jdk/make/gensrc/Gensrc-jdk.jlink.gmk index c841345c737..9ac5b1918a2 100644 --- a/jdk/make/gensrc/Gensrc-jdk.jlink.gmk +++ b/jdk/make/gensrc/Gensrc-jdk.jlink.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/GensrcIcons.gmk b/jdk/make/gensrc/GensrcIcons.gmk index 1970f18866b..62e31fb39f0 100644 --- a/jdk/make/gensrc/GensrcIcons.gmk +++ b/jdk/make/gensrc/GensrcIcons.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/GensrcLocaleData.gmk b/jdk/make/gensrc/GensrcLocaleData.gmk index 0acc8f9591f..e7d19951cce 100644 --- a/jdk/make/gensrc/GensrcLocaleData.gmk +++ b/jdk/make/gensrc/GensrcLocaleData.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/GensrcModuleLoaderMap.gmk b/jdk/make/gensrc/GensrcModuleLoaderMap.gmk index 859017d2a6d..365c83ddf90 100644 --- a/jdk/make/gensrc/GensrcModuleLoaderMap.gmk +++ b/jdk/make/gensrc/GensrcModuleLoaderMap.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/gensrc/GensrcVarHandles.gmk b/jdk/make/gensrc/GensrcVarHandles.gmk index b4a2bab9873..773c0f4c109 100644 --- a/jdk/make/gensrc/GensrcVarHandles.gmk +++ b/jdk/make/gensrc/GensrcVarHandles.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-java.scripting.gmk b/jdk/make/launcher/Launcher-java.scripting.gmk index 18b8ad46d45..057d2bf3aca 100644 --- a/jdk/make/launcher/Launcher-java.scripting.gmk +++ b/jdk/make/launcher/Launcher-java.scripting.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.compiler.gmk b/jdk/make/launcher/Launcher-jdk.compiler.gmk index 9c85acecdcc..5a1637d1dc0 100644 --- a/jdk/make/launcher/Launcher-jdk.compiler.gmk +++ b/jdk/make/launcher/Launcher-jdk.compiler.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.javadoc.gmk b/jdk/make/launcher/Launcher-jdk.javadoc.gmk index 04bc99baf7e..534a9d97341 100644 --- a/jdk/make/launcher/Launcher-jdk.javadoc.gmk +++ b/jdk/make/launcher/Launcher-jdk.javadoc.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.jdeps.gmk b/jdk/make/launcher/Launcher-jdk.jdeps.gmk index 4a69deede07..db29ecd88da 100644 --- a/jdk/make/launcher/Launcher-jdk.jdeps.gmk +++ b/jdk/make/launcher/Launcher-jdk.jdeps.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.jlink.gmk b/jdk/make/launcher/Launcher-jdk.jlink.gmk index bd270b0dc0a..92cb61e5572 100644 --- a/jdk/make/launcher/Launcher-jdk.jlink.gmk +++ b/jdk/make/launcher/Launcher-jdk.jlink.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.jstatd.gmk b/jdk/make/launcher/Launcher-jdk.jstatd.gmk index ee0ba2ad61d..aeb58557ff3 100644 --- a/jdk/make/launcher/Launcher-jdk.jstatd.gmk +++ b/jdk/make/launcher/Launcher-jdk.jstatd.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.pack200.gmk b/jdk/make/launcher/Launcher-jdk.pack200.gmk index af050554a79..ecdd329a1fd 100644 --- a/jdk/make/launcher/Launcher-jdk.pack200.gmk +++ b/jdk/make/launcher/Launcher-jdk.pack200.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/launcher/Launcher-jdk.scripting.nashorn.shell.gmk b/jdk/make/launcher/Launcher-jdk.scripting.nashorn.shell.gmk index 5cb872ae5cf..82311e69fd6 100644 --- a/jdk/make/launcher/Launcher-jdk.scripting.nashorn.shell.gmk +++ b/jdk/make/launcher/Launcher-jdk.scripting.nashorn.shell.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/lib/Lib-java.desktop.gmk b/jdk/make/lib/Lib-java.desktop.gmk index 5433fe96acb..1043ce777f2 100644 --- a/jdk/make/lib/Lib-java.desktop.gmk +++ b/jdk/make/lib/Lib-java.desktop.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/rmic/Rmic-java.management.gmk b/jdk/make/rmic/Rmic-java.management.gmk index 0452d5cbba5..0feaac3b88b 100644 --- a/jdk/make/rmic/Rmic-java.management.gmk +++ b/jdk/make/rmic/Rmic-java.management.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it diff --git a/jdk/make/rmic/RmicCommon.gmk b/jdk/make/rmic/RmicCommon.gmk index 611276ae467..bfc5b859b54 100644 --- a/jdk/make/rmic/RmicCommon.gmk +++ b/jdk/make/rmic/RmicCommon.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it From 1e5f273342e979bf4b12e0925cca6a9d2fb28519 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 09:50:37 +0200 Subject: [PATCH 06/43] 8167424: Various trivial fixes in build system Reviewed-by: erikj, tbell --- corba/make/gensrc/Gensrc-java.corba.gmk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/corba/make/gensrc/Gensrc-java.corba.gmk b/corba/make/gensrc/Gensrc-java.corba.gmk index f7f9b4ee53c..4899790c67f 100644 --- a/corba/make/gensrc/Gensrc-java.corba.gmk +++ b/corba/make/gensrc/Gensrc-java.corba.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it From 9c0a3e6ca925337e472cc62aadb3a6ace2be4ac0 Mon Sep 17 00:00:00 2001 From: Xue-Lei Andrew Fan Date: Tue, 11 Oct 2016 09:11:34 +0000 Subject: [PATCH 07/43] 8167472: Chrome interop regression with JDK-8148516 Reviewed-by: weijun --- .../share/classes/sun/security/ssl/EllipticCurvesExtension.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java b/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java index 632d0da18f1..d4f2848c973 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java @@ -282,7 +282,7 @@ final class EllipticCurvesExtension extends HelloExtension { private static int getPreferredCurve(int[] curves, AlgorithmConstraints constraints) { for (int curveId : curves) { - if (constraints.permits( + if (isSupported(curveId) && constraints.permits( EnumSet.of(CryptoPrimitive.KEY_AGREEMENT), "EC", idToParams.get(curveId))) { return curveId; From 33ae322e2cf02d421a4932ec67cbe1e41973f7a6 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Wed, 12 Oct 2016 11:49:09 +0200 Subject: [PATCH 08/43] 8157623: Make --enable-ccache work properly with CCACHE from the environment Reviewed-by: erikj --- common/autoconf/build-performance.m4 | 1 - common/autoconf/generated-configure.sh | 3 +-- 2 files changed, 1 insertion(+), 3 deletions(-) diff --git a/common/autoconf/build-performance.m4 b/common/autoconf/build-performance.m4 index 6ca891c3291..863875065a6 100644 --- a/common/autoconf/build-performance.m4 +++ b/common/autoconf/build-performance.m4 @@ -168,7 +168,6 @@ AC_DEFUN([BPERF_SETUP_CCACHE], [AS_HELP_STRING([--enable-ccache], [enable using ccache to speed up recompilations @<:@disabled@:>@])]) - CCACHE= CCACHE_STATUS= AC_MSG_CHECKING([is ccache enabled]) if test "x$enable_ccache" = xyes; then diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 6d6b0a5b5ce..b3923d51986 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -5103,7 +5103,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1476172133 +DATE_WHEN_GENERATED=1476265696 ############################################################################### # @@ -65251,7 +65251,6 @@ if test "${enable_ccache+set}" = set; then : fi - CCACHE= CCACHE_STATUS= { $as_echo "$as_me:${as_lineno-$LINENO}: checking is ccache enabled" >&5 $as_echo_n "checking is ccache enabled... " >&6; } From dde68e918cf161067a7ec83b8121a8fd92143f03 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Tue, 11 Oct 2016 11:28:19 +0200 Subject: [PATCH 09/43] 8158181: Stop adding missing newline to manifest files Reviewed-by: erikj --- make/common/JarArchive.gmk | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/make/common/JarArchive.gmk b/make/common/JarArchive.gmk index 71d5e23abc8..4ca2af1a413 100644 --- a/make/common/JarArchive.gmk +++ b/make/common/JarArchive.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -242,7 +242,7 @@ define SetupJarArchiveBody # potential changes. $$(if $$(filter $$($1_VARDEPS_FILE) $$($1_MANIFEST), $$?), \ $$(if $$($1_MANIFEST), \ - $(SED) -e '$(DOLLAR)$(DOLLAR)a\' $$($1_MANIFEST) > $$($1_MANIFEST_FILE) $$(NEWLINE) \ + $(CP) $$($1_MANIFEST) $$($1_MANIFEST_FILE) $$(NEWLINE) \ , \ $(RM) $$($1_MANIFEST_FILE) && $(TOUCH) $$($1_MANIFEST_FILE) $$(NEWLINE)) \ $$(if $$($1_JARMAIN), \ From b09d8ad0e6f32fa1fd3e0f850660ef3399087741 Mon Sep 17 00:00:00 2001 From: Vyom Tewari Date: Tue, 11 Oct 2016 15:12:40 +0530 Subject: [PATCH 10/43] 8163482: java.net.URLPermission.getActions() adds a trailing colon when header-names is empty Reviewed-by: chegar, dfuchs --- jdk/src/java.base/share/classes/java/net/URLPermission.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/net/URLPermission.java b/jdk/src/java.base/share/classes/java/net/URLPermission.java index 0c38008cb13..e78c7aee68c 100644 --- a/jdk/src/java.base/share/classes/java/net/URLPermission.java +++ b/jdk/src/java.base/share/classes/java/net/URLPermission.java @@ -217,7 +217,7 @@ public final class URLPermission extends Permission { * where method-names is the list of methods separated by commas * and header-names is the list of permitted headers separated by commas. * There is no white space in the returned String. If header-names is empty - * then the colon separator will not be present. + * then the colon separator may not be present. */ public String getActions() { return actions; From 7bf6362c3ae54a52d87171b0aa0079c26ed9fa73 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Tue, 11 Oct 2016 12:25:54 +0200 Subject: [PATCH 11/43] 8167387: libjimage.so has a bad runpath Reviewed-by: tbell, ihse --- jdk/make/lib/CoreLibraries.gmk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/make/lib/CoreLibraries.gmk b/jdk/make/lib/CoreLibraries.gmk index a5417be9985..345c4253389 100644 --- a/jdk/make/lib/CoreLibraries.gmk +++ b/jdk/make/lib/CoreLibraries.gmk @@ -255,7 +255,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJIMAGE, \ CXXFLAGS := $(CXXFLAGS_JDKLIB) $(JIMAGELIB_CPPFLAGS), \ CFLAGS_unix := -UDEBUG, \ MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjimage/mapfile-vers, \ - LDFLAGS := $(LDFLAGS_JDKLIB) \ + LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \ $(call SET_SHARED_LIBRARY_ORIGIN), \ LDFLAGS_windows := -export:JIMAGE_Open -export:JIMAGE_Close \ -export:JIMAGE_PackageToModule \ From b765ef344a970e3e12974cf161fe31bee60ce8ca Mon Sep 17 00:00:00 2001 From: Jan Lahoda Date: Tue, 11 Oct 2016 12:33:15 +0200 Subject: [PATCH 12/43] 8166890: JShell: locks forever when input is piped Only read cursor position if connected to a terminal. Reviewed-by: rfield, shinyafox --- .../share/classes/jdk/internal/jline/console/ConsoleReader.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/jdk.internal.le/share/classes/jdk/internal/jline/console/ConsoleReader.java b/jdk/src/jdk.internal.le/share/classes/jdk/internal/jline/console/ConsoleReader.java index 84341e1e181..999b0f7bd91 100644 --- a/jdk/src/jdk.internal.le/share/classes/jdk/internal/jline/console/ConsoleReader.java +++ b/jdk/src/jdk.internal.le/share/classes/jdk/internal/jline/console/ConsoleReader.java @@ -2339,7 +2339,7 @@ public class ConsoleReader Stack pushBackChar = new Stack(); - if (terminal.isAnsiSupported()) { + if (terminal.isAnsiSupported() && System.console() != null) { //detect the prompt length by reading the cursor position from the terminal //the real prompt length could differ from the simple prompt length due to //use of escape sequences: From 909e2244c85b8d42c65f2ab818ff95a11e9de71d Mon Sep 17 00:00:00 2001 From: Bradford Wetmore Date: Tue, 11 Oct 2016 15:49:37 -0700 Subject: [PATCH 13/43] 8167459: Add debug output for indicating if a chosen ciphersuite was legacy Reviewed-by: xuelei --- .../share/classes/sun/security/ssl/ServerHandshaker.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java b/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java index c68e7431053..a8870960ca6 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java @@ -1172,11 +1172,18 @@ final class ServerHandshaker extends Handshaker { if (trySetCipherSuite(suite) == false) { continue; } + + if (debug != null && Debug.isOn("handshake")) { + System.out.println("Standard ciphersuite chosen: " + suite); + } return; } for (CipherSuite suite : legacySuites) { if (trySetCipherSuite(suite)) { + if (debug != null && Debug.isOn("handshake")) { + System.out.println("Legacy ciphersuite chosen: " + suite); + } return; } } From 2fc1b1389af8cd3bf06a6d58b4c4f75f5f67575d Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Tue, 11 Oct 2016 16:25:52 -0700 Subject: [PATCH 14/43] 8167524: Rogue character in Stream javadoc Reviewed-by: smarks, darcy --- jdk/src/java.base/share/classes/java/util/stream/Stream.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/util/stream/Stream.java b/jdk/src/java.base/share/classes/java/util/stream/Stream.java index 62ed4c82b6e..1ec21ed2b57 100644 --- a/jdk/src/java.base/share/classes/java/util/stream/Stream.java +++ b/jdk/src/java.base/share/classes/java/util/stream/Stream.java @@ -282,7 +282,7 @@ public interface Stream extends BaseStream> { */ Stream flatMap(Function> mapper); - /**: + /** * Returns an {@code IntStream} consisting of the results of replacing each * element of this stream with the contents of a mapped stream produced by * applying the provided mapping function to each element. Each mapped From b414bb7023209114f66ab6ecb0a81efe0e33be57 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Tue, 11 Oct 2016 17:39:31 -0700 Subject: [PATCH 15/43] 8152530: NullPointerException when xmlns="" Reviewed-by: dfuchs, naoto, lancea --- .../internal/xsltc/trax/StAXStream2SAX.java | 11 ++++--- .../unittest/transform/StAXSourceTest.java | 31 +++++++++++++++++++ 2 files changed, 38 insertions(+), 4 deletions(-) diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/StAXStream2SAX.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/StAXStream2SAX.java index 1b2705653b2..47e74c91b75 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/StAXStream2SAX.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/StAXStream2SAX.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -305,9 +305,12 @@ public class StAXStream2SAX implements XMLReader, Locator { if (prefix == null) { // true for default namespace prefix = ""; } - _sax.startPrefixMapping( - prefix, - staxStreamReader.getNamespaceURI(i)); + String uri = staxStreamReader.getNamespaceURI(i); + if (uri == null && prefix.isEmpty()) { // true for default namespace + uri = ""; + } + + _sax.startPrefixMapping(prefix, uri); } // fire startElement diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/StAXSourceTest.java b/jaxp/test/javax/xml/jaxp/unittest/transform/StAXSourceTest.java index 09df03442e5..3237cacb4bc 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/transform/StAXSourceTest.java +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/StAXSourceTest.java @@ -30,7 +30,9 @@ import javax.xml.stream.XMLEventReader; import javax.xml.stream.XMLEventWriter; import javax.xml.stream.XMLInputFactory; import javax.xml.stream.XMLOutputFactory; +import javax.xml.stream.XMLStreamConstants; import javax.xml.stream.XMLStreamException; +import javax.xml.stream.XMLStreamReader; import javax.xml.transform.Transformer; import javax.xml.transform.TransformerConfigurationException; import javax.xml.transform.TransformerException; @@ -38,6 +40,7 @@ import javax.xml.transform.TransformerFactory; import javax.xml.transform.dom.DOMResult; import javax.xml.transform.stax.StAXResult; import javax.xml.transform.stax.StAXSource; +import javax.xml.transform.stream.StreamResult; import org.testng.Assert; import org.testng.annotations.Listeners; @@ -45,6 +48,7 @@ import org.testng.annotations.Test; /* * @test + * @bug 8152530 * @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest * @run testng/othervm -DrunSecMngr=true transform.StAXSourceTest * @run testng/othervm transform.StAXSourceTest @@ -52,6 +56,33 @@ import org.testng.annotations.Test; */ @Listeners({jaxp.library.FilePolicy.class}) public class StAXSourceTest { + /** + * @bug 8152530 + * Verifies that StAXSource handles empty namespace properly. NPE was thrown + * before the fix. + * @throws Exception if the test fails + */ + @Test + public final void testStAXSourceWEmptyNS() throws Exception { + String xml = "\n" + + "\n" + + " \n" + + " \n" + + " \n" + + " \n" + + " "; + + XMLInputFactory xif = XMLInputFactory.newInstance(); + XMLStreamReader xsr = xif.createXMLStreamReader(new StringReader(xml)); + xsr.nextTag(); + TransformerFactory tf = TransformerFactory.newInstance(); + Transformer t = tf.newTransformer(); + while (xsr.nextTag() == XMLStreamConstants.START_ELEMENT && xsr.getLocalName().equals("Entity")) { + StringWriter stringResult = new StringWriter(); + t.transform(new StAXSource(xsr), new StreamResult(stringResult)); + System.out.println("result: \n" + stringResult.toString()); + } + } @Test public final void testStAXSource() throws XMLStreamException { From 7975bee5dc356a0295abcf358b1512cb31a01349 Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Wed, 12 Oct 2016 13:23:15 +0200 Subject: [PATCH 16/43] 8167443: Nashorn static method linking bypasses autoexported linkers Reviewed-by: hannesw, sundar --- .../internal/runtime/linker/Bootstrap.java | 7 +++- .../linker/NashornStaticClassLinker.java | 2 +- .../test/DynamicLinkerFactoryTest.java | 29 +++++++++----- ...achedAutoLoadedDynamicLinkerException.java | 33 ---------------- .../dynalink/test/TestLinkerOperation.java | 31 --------------- .../TrustedGuardingDynamicLinkerExporter.java | 38 ++++++++++++------- 6 files changed, 50 insertions(+), 90 deletions(-) delete mode 100644 nashorn/test/src/jdk/dynalink/test/ReachedAutoLoadedDynamicLinkerException.java delete mode 100644 nashorn/test/src/jdk/dynalink/test/TestLinkerOperation.java diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java index cdbbb0fea22..868b3b69069 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java @@ -78,14 +78,17 @@ public final class Bootstrap { prioritizedLinkers = new GuardingDynamicLinker[] { new NashornLinker(), new NashornPrimitiveLinker(), - new NashornStaticClassLinker(beansLinker), new BoundCallableLinker(), new JavaSuperAdapterLinker(beansLinker), new JSObjectLinker(nashornBeansLinker), new BrowserJSObjectLinker(nashornBeansLinker), new ReflectionCheckLinker() }; - fallbackLinkers = new GuardingDynamicLinker[] {nashornBeansLinker, new NashornBottomLinker() }; + fallbackLinkers = new GuardingDynamicLinker[] { + new NashornStaticClassLinker(beansLinker), + nashornBeansLinker, + new NashornBottomLinker() + }; } // do not create me!! diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java index 99ceb73e087..01a5657268b 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java @@ -68,7 +68,7 @@ final class NashornStaticClassLinker implements TypeBasedGuardingDynamicLinker { @Override public GuardedInvocation getGuardedInvocation(final LinkRequest request, final LinkerServices linkerServices) throws Exception { final Object self = request.getReceiver(); - if (self.getClass() != StaticClass.class) { + if (self == null || self.getClass() != StaticClass.class) { return null; } final Class receiverClass = ((StaticClass) self).getRepresentedClass(); diff --git a/nashorn/test/src/jdk/dynalink/test/DynamicLinkerFactoryTest.java b/nashorn/test/src/jdk/dynalink/test/DynamicLinkerFactoryTest.java index a4e2a82b6ff..2addefbb3e4 100644 --- a/nashorn/test/src/jdk/dynalink/test/DynamicLinkerFactoryTest.java +++ b/nashorn/test/src/jdk/dynalink/test/DynamicLinkerFactoryTest.java @@ -39,6 +39,7 @@ import jdk.dynalink.NamedOperation; import jdk.dynalink.NoSuchDynamicMethodException; import jdk.dynalink.Operation; import jdk.dynalink.StandardOperation; +import jdk.dynalink.beans.StaticClass; import jdk.dynalink.linker.GuardedInvocation; import jdk.dynalink.linker.GuardingDynamicLinker; import jdk.dynalink.linker.LinkRequest; @@ -234,6 +235,15 @@ public class DynamicLinkerFactoryTest { @Test public void autoLoadedLinkerTest() { + testAutoLoadedLinkerInvoked(new Object(), "toString"); + } + + @Test + public void autoLoadedLinkerSeesStaticMethod() { + testAutoLoadedLinkerInvoked(StaticClass.forClass(System.class), "currentTimeMillis"); + } + + private static void testAutoLoadedLinkerInvoked(final Object target, final String methodName) { final DynamicLinkerFactory factory = newDynamicLinkerFactory(false); final DynamicLinker linker = factory.createLinker(); @@ -241,22 +251,21 @@ public class DynamicLinkerFactoryTest { checkOneAutoLoadingError(factory); final MethodType mt = MethodType.methodType(Object.class, Object.class); - // create a callsite with TestLinkerOperation - final CallSite cs = linker.link(new SimpleRelinkableCallSite(new CallSiteDescriptor( - MethodHandles.publicLookup(), new TestLinkerOperation(), mt))); - boolean reachedAutoLinker = false; - + final CallSiteDescriptor testDescriptor = new CallSiteDescriptor(MethodHandles.publicLookup(), + new NamedOperation(StandardOperation.GET_METHOD, methodName), mt); + final CallSite cs = linker.link(new SimpleRelinkableCallSite(testDescriptor)); + TrustedGuardingDynamicLinkerExporter.enable(); try { - cs.getTarget().invoke(new Object()); - } catch (final ReachedAutoLoadedDynamicLinkerException e) { - // TrustedGuardingDynamicLinkerExporter threw exception on TestLinkerOperation as expected! - reachedAutoLinker = true; + cs.getTarget().invoke(target); + // The linker was loaded and it observed our invocation + Assert.assertTrue(TrustedGuardingDynamicLinkerExporter.isLastCallSiteDescriptor(testDescriptor)); } catch (final Throwable th) { throw new RuntimeException(th); + } finally { + TrustedGuardingDynamicLinkerExporter.disable(); } - Assert.assertTrue(reachedAutoLinker); } @Test diff --git a/nashorn/test/src/jdk/dynalink/test/ReachedAutoLoadedDynamicLinkerException.java b/nashorn/test/src/jdk/dynalink/test/ReachedAutoLoadedDynamicLinkerException.java deleted file mode 100644 index 0a6283599ec..00000000000 --- a/nashorn/test/src/jdk/dynalink/test/ReachedAutoLoadedDynamicLinkerException.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * 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.dynalink.test; - -/** - * Exception used to signal to the test method that the control has reached auto loaded - * dynamic linker. - */ -public final class ReachedAutoLoadedDynamicLinkerException extends RuntimeException { -} diff --git a/nashorn/test/src/jdk/dynalink/test/TestLinkerOperation.java b/nashorn/test/src/jdk/dynalink/test/TestLinkerOperation.java deleted file mode 100644 index 4a62bfaa046..00000000000 --- a/nashorn/test/src/jdk/dynalink/test/TestLinkerOperation.java +++ /dev/null @@ -1,31 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * 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.dynalink.test; - -import jdk.dynalink.Operation; - -public final class TestLinkerOperation implements Operation { -} diff --git a/nashorn/test/src/jdk/dynalink/test/TrustedGuardingDynamicLinkerExporter.java b/nashorn/test/src/jdk/dynalink/test/TrustedGuardingDynamicLinkerExporter.java index 9e7b63f0c51..e9119440a7f 100644 --- a/nashorn/test/src/jdk/dynalink/test/TrustedGuardingDynamicLinkerExporter.java +++ b/nashorn/test/src/jdk/dynalink/test/TrustedGuardingDynamicLinkerExporter.java @@ -25,8 +25,8 @@ package jdk.dynalink.test; -import java.util.ArrayList; import java.util.List; +import jdk.dynalink.CallSiteDescriptor; import jdk.dynalink.linker.GuardingDynamicLinker; import jdk.dynalink.linker.GuardingDynamicLinkerExporter; import jdk.dynalink.linker.LinkRequest; @@ -37,20 +37,32 @@ import jdk.dynalink.linker.LinkerServices; */ public final class TrustedGuardingDynamicLinkerExporter extends GuardingDynamicLinkerExporter { + private static final ThreadLocal lastDescriptor = new ThreadLocal<>(); + private static boolean enabled = false; + + public static void enable() { + reset(true); + } + + public static void disable() { + reset(false); + } + public static boolean isLastCallSiteDescriptor(final CallSiteDescriptor desc) { + return lastDescriptor.get() == desc; + } + + private static void reset(final boolean enable) { + lastDescriptor.set(null); + enabled = enable; + } + @Override public List get() { - final ArrayList linkers = new ArrayList<>(); - linkers.add((GuardingDynamicLinker) (final LinkRequest linkRequest, final LinkerServices linkerServices) -> { - // handle only the TestLinkerOperation instances - if (linkRequest.getCallSiteDescriptor().getOperation() instanceof TestLinkerOperation) { - System.out.println("inside " + this.getClass().getName()); - // throw exception to signal to the test method that the control has reached here! - throw new ReachedAutoLoadedDynamicLinkerException(); - } else { - // any other operation! - return null; + return List.of(((GuardingDynamicLinker) (final LinkRequest linkRequest, final LinkerServices linkerServices) -> { + if (enabled) { + lastDescriptor.set(linkRequest.getCallSiteDescriptor()); } - }); - return linkers; + return null; + })); } } From a467175dda93b8fb78efdae0dff9295eac46fec2 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Wed, 12 Oct 2016 14:22:55 +0200 Subject: [PATCH 17/43] 8167488: Race condition in build with new exploded-image-optimize target Reviewed-by: tbell, ihse --- make/Main.gmk | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/make/Main.gmk b/make/Main.gmk index 44c8c192172..cad7b5b19f5 100644 --- a/make/Main.gmk +++ b/make/Main.gmk @@ -548,7 +548,7 @@ else # The demos are currently linking to libjvm and libjava, just like all other # jdk libs, even though they don't need to. To avoid warnings, make sure they # aren't built until after libjava and libjvm are available to link to. - demos-jdk: $(JAVA_TARGETS) + demos-jdk: java.base-libs exploded-image-optimize # Declare dependency from -java to -gensrc $(foreach m, $(GENSRC_MODULES), $(eval $m-java: $m-gensrc)) @@ -698,7 +698,7 @@ else test-make: clean-test-make - build-test-lib: java + build-test-lib: exploded-image-optimize build-test-failure-handler: interim-langtools From da8b135bcfcffed5421f682324ed765ce90c3f0b Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Wed, 12 Oct 2016 14:25:07 +0200 Subject: [PATCH 18/43] 8167479: arm 32/64 slowdebug fails to build on unpack200 Reviewed-by: ihse --- jdk/make/launcher/Launcher-jdk.pack200.gmk | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/jdk/make/launcher/Launcher-jdk.pack200.gmk b/jdk/make/launcher/Launcher-jdk.pack200.gmk index ecdd329a1fd..32b29b0c598 100644 --- a/jdk/make/launcher/Launcher-jdk.pack200.gmk +++ b/jdk/make/launcher/Launcher-jdk.pack200.gmk @@ -58,10 +58,6 @@ else endif -ifeq ($(OPENJDK_TARGET_OS), solaris) - UNPACKEXE_TOOLCHAIN := TOOLCHAIN_LINK_CXX -endif - UNPACK_MAPFILE_DIR := $(JDK_TOPDIR)/make/mapfiles/libunpack UNPACK_MAPFILE_PLATFORM_FILE := \ $(UNPACK_MAPFILE_DIR)/mapfile-vers-unpack200-$(OPENJDK_TARGET_OS)-$(OPENJDK_TARGET_CPU_ARCH) @@ -79,7 +75,7 @@ endif $(eval $(call SetupNativeCompilation,BUILD_UNPACKEXE, \ SRC := $(UNPACKEXE_SRC), \ - TOOLCHAIN := $(UNPACKEXE_TOOLCHAIN), \ + TOOLCHAIN := TOOLCHAIN_LINK_CXX, \ OPTIMIZATION := LOW, \ CFLAGS := $(UNPACKEXE_CFLAGS) $(CXXFLAGS_JDKEXE) -DFULL, \ CFLAGS_release := -DPRODUCT, \ From a8ac9204749a4c2f752d6395300525bdc6cb2178 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Wed, 12 Oct 2016 14:29:21 +0200 Subject: [PATCH 19/43] 8166937: [Solaris] Missing libjvm_db.so and libjvm_dtrace.so from JDK 9 b138 Reviewed-by: ihse, alanbur --- common/autoconf/basics.m4 | 10 +++++++--- common/autoconf/generated-configure.sh | 26 ++++++++++---------------- common/conf/jib-profiles.js | 6 ++++-- 3 files changed, 21 insertions(+), 21 deletions(-) diff --git a/common/autoconf/basics.m4 b/common/autoconf/basics.m4 index 8404ca42d02..7f8c42f6b98 100644 --- a/common/autoconf/basics.m4 +++ b/common/autoconf/basics.m4 @@ -428,9 +428,10 @@ AC_DEFUN([BASIC_SETUP_TOOL], # Call BASIC_SETUP_TOOL with AC_PATH_PROGS to locate the tool # $1: variable to set # $2: executable name (or list of names) to look for +# $3: [path] AC_DEFUN([BASIC_PATH_PROGS], [ - BASIC_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2)]) + BASIC_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2, , $3)]) ]) # Call BASIC_SETUP_TOOL with AC_CHECK_TOOLS to locate the tool @@ -444,9 +445,10 @@ AC_DEFUN([BASIC_CHECK_TOOLS], # Like BASIC_PATH_PROGS but fails if no tool was found. # $1: variable to set # $2: executable name (or list of names) to look for +# $3: [path] AC_DEFUN([BASIC_REQUIRE_PROGS], [ - BASIC_PATH_PROGS($1, $2) + BASIC_PATH_PROGS($1, $2, , $3) BASIC_CHECK_NONEMPTY($1) ]) @@ -1065,7 +1067,9 @@ AC_DEFUN_ONCE([BASIC_SETUP_COMPLEX_TOOLS], BASIC_PATH_PROGS(HG, hg) BASIC_PATH_PROGS(STAT, stat) BASIC_PATH_PROGS(TIME, time) - BASIC_PATH_PROGS(DTRACE, dtrace) + # Dtrace is usually found in /usr/sbin on Solaris, but that directory may not + # be in the user path. + BASIC_PATH_PROGS(DTRACE, dtrace, $PATH:/usr/sbin) BASIC_PATH_PROGS(PATCH, [gpatch patch]) # Check if it's GNU time IS_GNU_TIME=`$TIME --version 2>&1 | $GREP 'GNU time'` diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index b3923d51986..2eca459ed04 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -1111,7 +1111,6 @@ infodir docdir oldincludedir includedir -runstatedir localstatedir sharedstatedir sysconfdir @@ -1390,7 +1389,6 @@ datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' -runstatedir='${localstatedir}/run' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' @@ -1643,15 +1641,6 @@ do | -silent | --silent | --silen | --sile | --sil) silent=yes ;; - -runstatedir | --runstatedir | --runstatedi | --runstated \ - | --runstate | --runstat | --runsta | --runst | --runs \ - | --run | --ru | --r) - ac_prev=runstatedir ;; - -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \ - | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \ - | --run=* | --ru=* | --r=*) - runstatedir=$ac_optarg ;; - -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ @@ -1789,7 +1778,7 @@ fi for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ - libdir localedir mandir runstatedir + libdir localedir mandir do eval ac_val=\$$ac_var # Remove trailing slashes. @@ -1942,7 +1931,6 @@ Fine tuning of the installation directories: --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] - --runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] @@ -3669,6 +3657,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Call BASIC_SETUP_TOOL with AC_PATH_PROGS to locate the tool # $1: variable to set # $2: executable name (or list of names) to look for +# $3: [path] # Call BASIC_SETUP_TOOL with AC_CHECK_TOOLS to locate the tool @@ -3679,6 +3668,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Like BASIC_PATH_PROGS but fails if no tool was found. # $1: variable to set # $2: executable name (or list of names) to look for +# $3: [path] # Like BASIC_SETUP_TOOL but fails if no tool was found. @@ -5103,7 +5093,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1476265696 +DATE_WHEN_GENERATED=1476275292 ############################################################################### # @@ -22781,6 +22771,8 @@ $as_echo "$tool_specified" >&6; } fi + # Dtrace is usually found in /usr/sbin on Solaris, but that directory may not + # be in the user path. # Publish this variable in the help. @@ -22803,7 +22795,8 @@ else ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH +as_dummy="$PATH:/usr/sbin" +for as_dir in $as_dummy do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. @@ -22861,7 +22854,8 @@ else ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH +as_dummy="$PATH:/usr/sbin" +for as_dir in $as_dummy do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. diff --git a/common/conf/jib-profiles.js b/common/conf/jib-profiles.js index a9f3d8d0289..fa3c5749f8c 100644 --- a/common/conf/jib-profiles.js +++ b/common/conf/jib-profiles.js @@ -287,7 +287,8 @@ var getJibProfilesProfiles = function (input, common) { target_os: "solaris", target_cpu: "x64", dependencies: concat(common.dependencies, "devkit", "cups"), - configure_args: concat(common.configure_args, "--with-zlib=system"), + configure_args: concat(common.configure_args, "--with-zlib=system", + "--enable-dtrace"), default_make_targets: common.default_make_targets }, @@ -295,7 +296,8 @@ var getJibProfilesProfiles = function (input, common) { target_os: "solaris", target_cpu: "sparcv9", dependencies: concat(common.dependencies, "devkit", "cups"), - configure_args: concat(common.configure_args, "--with-zlib=system"), + configure_args: concat(common.configure_args, "--with-zlib=system", + "--enable-dtrace"), default_make_targets: common.default_make_targets }, From 41e797f4da74e898ea32042d1619cc37383df26d Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Wed, 12 Oct 2016 09:46:35 -0400 Subject: [PATCH 20/43] 8162723: Array index overflow in Base64 utility class Reviewed-by: ascarpino, jnimeh --- .../org/apache/xml/internal/security/utils/Base64.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/jdk/src/java.xml.crypto/share/classes/com/sun/org/apache/xml/internal/security/utils/Base64.java b/jdk/src/java.xml.crypto/share/classes/com/sun/org/apache/xml/internal/security/utils/Base64.java index de822922b36..37dd499e727 100644 --- a/jdk/src/java.xml.crypto/share/classes/com/sun/org/apache/xml/internal/security/utils/Base64.java +++ b/jdk/src/java.xml.crypto/share/classes/com/sun/org/apache/xml/internal/security/utils/Base64.java @@ -376,14 +376,14 @@ public class Base64 { return null; } - int lengthDataBits = binaryData.length * EIGHTBIT; - if (lengthDataBits == 0) { + long lengthDataBits = ((long) binaryData.length) * ((long) EIGHTBIT); + if (lengthDataBits == 0L) { return ""; } - int fewerThan24bits = lengthDataBits % TWENTYFOURBITGROUP; - int numberTriplets = lengthDataBits / TWENTYFOURBITGROUP; - int numberQuartet = fewerThan24bits != 0 ? numberTriplets + 1 : numberTriplets; + long fewerThan24bits = lengthDataBits % TWENTYFOURBITGROUP; + int numberTriplets = (int) (lengthDataBits / TWENTYFOURBITGROUP); + int numberQuartet = fewerThan24bits != 0L ? numberTriplets + 1 : numberTriplets; int quartesPerLine = length / 4; int numberLines = (numberQuartet - 1) / quartesPerLine; char encodedData[] = null; From c299fc425d76ec16716aad94eb2b34002ff94c86 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Wed, 12 Oct 2016 22:42:23 +0530 Subject: [PATCH 21/43] 8167614: Avoid module dependency from jdk.dynalink to jdk.internal.module of java.base module Reviewed-by: jlaskey, alanb --- .../beans/CallerSensitiveDynamicMethod.java | 52 +------------------ .../jdk/nashorn/internal/runtime/Context.java | 9 ++++ .../internal/runtime/ScriptLoader.java | 19 +++++-- .../internal/runtime/StructureLoader.java | 1 + 4 files changed, 27 insertions(+), 54 deletions(-) diff --git a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java index 467da4b9c75..016873489d5 100644 --- a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java +++ b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java @@ -100,7 +100,6 @@ import jdk.dynalink.CallSiteDescriptor; import jdk.dynalink.SecureLookupSupplier; import jdk.dynalink.internal.AccessControlContextFactory; import jdk.dynalink.linker.support.Lookup; -import jdk.internal.module.Modules; import jdk.internal.reflect.CallerSensitive; @@ -180,57 +179,10 @@ class CallerSensitiveDynamicMethod extends SingleDynamicMethod { } private static MethodHandle unreflect(final MethodHandles.Lookup lookup, final Method m) { - try { - return Lookup.unreflect(lookup, m); - } catch (final IllegalAccessError iae) { - if (addModuleRead(lookup, m)) { - try { - return Lookup.unreflect(lookup, m); - } catch (final IllegalAccessError e2) { - // fall through and throw original error as cause - } - } - throw iae; - } + return Lookup.unreflect(lookup, m); } private static MethodHandle unreflectConstructor(final MethodHandles.Lookup lookup, final Constructor c) { - try { - return Lookup.unreflectConstructor(lookup, c); - } catch (final IllegalAccessError iae) { - if (addModuleRead(lookup, c)) { - try { - return Lookup.unreflectConstructor(lookup, c); - } catch (final IllegalAccessError e2) { - // fall through and throw original error as cause - } - } - throw iae; - } - } - - - private static boolean addModuleRead(final MethodHandles.Lookup lookup, final Executable e) { - // Don't add module read link if this is not a CallerSensitive member - if (!e.isAnnotationPresent(CallerSensitive.class)) { - return false; - } - - // If the lookup is public lookup, don't bother adding module read link! - // public lookup cannot unreflect caller sensitives anyway! - if (lookup == MethodHandles.publicLookup()) { - return false; - } - - // try to add missing module read from using module to declararing module! - final Class declClass = e.getDeclaringClass(); - final Module useModule = lookup.lookupClass().getModule(); - final Module declModule = declClass.getModule(); - if (useModule != null && declModule != null && declModule.isExported(declClass.getPackageName())) { - Modules.addReads(useModule, declModule); - return true; - } - - return false; + return Lookup.unreflectConstructor(lookup, c); } } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java index 1c8c0219ee0..96bfda4ebef 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java @@ -389,6 +389,15 @@ public final class Context { // is created, and invalidated forever once the second global is created. private final AtomicReference globalConstantsRef = new AtomicReference<>(); + // Are java.sql, java.sql.rowset modules found in the system? + static final boolean javaSqlFound, javaSqlRowsetFound; + + static { + final Layer boot = Layer.boot(); + javaSqlFound = boot.findModule("java.sql").isPresent(); + javaSqlRowsetFound = boot.findModule("java.sql.rowset").isPresent(); + } + /** * Get the current global scope * @return the current global scope diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java index b6310a7ba9e..c37f1994f92 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java @@ -68,12 +68,23 @@ final class ScriptLoader extends NashornLoader { private Module createModule(final String moduleName) { final Module structMod = context.getStructLoader().getModule(); - final ModuleDescriptor descriptor - = new ModuleDescriptor.Builder(moduleName) + final ModuleDescriptor.Builder builder = + new ModuleDescriptor.Builder(moduleName) + .requires("java.base") + .requires("java.logging") .requires(NASHORN_MODULE.getName()) .requires(structMod.getName()) - .conceals(SCRIPTS_PKG) - .build(); + .conceals(SCRIPTS_PKG); + + if (Context.javaSqlFound) { + builder.requires("java.sql"); + } + + if (Context.javaSqlRowsetFound) { + builder.requires("java.sql.rowset"); + } + + final ModuleDescriptor descriptor = builder.build(); final Module mod = Context.createModuleTrusted(structMod.getLayer(), descriptor, this); loadModuleManipulator(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java index d9950e7be3f..be7d38be2a0 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java @@ -64,6 +64,7 @@ final class StructureLoader extends NashornLoader { private Module createModule(final String moduleName) { final ModuleDescriptor descriptor = new ModuleDescriptor.Builder(moduleName) + .requires("java.base") .requires(NASHORN_MODULE.getName()) .conceals(SCRIPTS_PKG) .build(); From 8c7dc293890ba57bc2bb994117f3ee879aaf922e Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Wed, 12 Oct 2016 22:44:43 +0530 Subject: [PATCH 22/43] 8167614: Avoid module dependency from jdk.dynalink to jdk.internal.module of java.base module Reviewed-by: jlaskey, alanb --- jdk/src/java.base/share/classes/module-info.java | 1 - 1 file changed, 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/module-info.java b/jdk/src/java.base/share/classes/module-info.java index 4cb223881bc..e376a502579 100644 --- a/jdk/src/java.base/share/classes/module-info.java +++ b/jdk/src/java.base/share/classes/module-info.java @@ -154,7 +154,6 @@ module java.base { exports jdk.internal.module to java.instrument, java.management, - jdk.dynalink, jdk.jartool, jdk.jlink; exports jdk.internal.misc to From a19fc7fbdb49b91c008de8b5ffb28b0bd0ba14f7 Mon Sep 17 00:00:00 2001 From: Jonathan Bluett-Duncan Date: Wed, 12 Oct 2016 11:54:38 -0700 Subject: [PATCH 23/43] 8134373: use collections convenience factories in the JDK Reviewed-by: scolebourne, prappo, dfuchs, redestad, smarks --- .../java/lang/module/ModuleFinder.java | 7 +- .../share/classes/java/net/CookieManager.java | 8 +-- .../java/nio/file/FileTreeIterator.java | 5 +- .../classes/java/nio/file/FileTreeWalker.java | 2 +- .../classes/java/security/Signature.java | 16 ++--- .../share/classes/java/time/Duration.java | 5 +- .../share/classes/java/time/Period.java | 5 +- .../share/classes/java/time/ZoneId.java | 67 +++++++++---------- .../java/time/chrono/ChronoPeriodImpl.java | 5 +- .../java/time/chrono/HijrahChronology.java | 6 +- .../java/time/chrono/IsoChronology.java | 3 +- .../java/time/chrono/JapaneseChronology.java | 3 +- .../java/time/chrono/MinguoChronology.java | 3 +- .../time/chrono/ThaiBuddhistChronology.java | 2 +- .../java/time/format/DateTimeFormatter.java | 1 + .../java/time/zone/ZoneOffsetTransition.java | 4 +- .../classes/java/time/zone/ZoneRules.java | 3 +- .../classes/java/util/ResourceBundle.java | 17 ++--- .../classes/java/util/stream/Collectors.java | 5 +- 19 files changed, 67 insertions(+), 100 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/module/ModuleFinder.java b/jdk/src/java.base/share/classes/java/lang/module/ModuleFinder.java index a108e467a33..9dd5b54c8cc 100644 --- a/jdk/src/java.base/share/classes/java/lang/module/ModuleFinder.java +++ b/jdk/src/java.base/share/classes/java/lang/module/ModuleFinder.java @@ -33,7 +33,6 @@ import java.nio.file.Paths; import java.security.AccessController; import java.security.Permission; import java.security.PrivilegedAction; -import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; @@ -333,7 +332,7 @@ public interface ModuleFinder { * *

When locating modules then any exceptions or errors thrown by the * {@code find} or {@code findAll} methods of the underlying module finders - * will be propogated to the caller of the resulting module finder's + * will be propagated to the caller of the resulting module finder's * {@code find} or {@code findAll} methods.

* * @param finders @@ -342,8 +341,8 @@ public interface ModuleFinder { * @return A {@code ModuleFinder} that composes a sequence of module finders */ static ModuleFinder compose(ModuleFinder... finders) { - final List finderList = Arrays.asList(finders); - finderList.forEach(Objects::requireNonNull); + // copy the list, also checking for nulls + final List finderList = List.of(finders); return new ModuleFinder() { private final Map nameToModule = new HashMap<>(); diff --git a/jdk/src/java.base/share/classes/java/net/CookieManager.java b/jdk/src/java.base/share/classes/java/net/CookieManager.java index fb3fa356e99..13ef9e468a0 100644 --- a/jdk/src/java.base/share/classes/java/net/CookieManager.java +++ b/jdk/src/java.base/share/classes/java/net/CookieManager.java @@ -81,7 +81,7 @@ import sun.util.logging.PlatformLogger; *
  • * Currently, only CookieStore.add(URI, HttpCookie) and CookieStore.get(URI) * are used by CookieManager. Others are for completeness and might be needed - * by a more sophisticated CookieStore implementation, e.g. a NetscapeCookieSotre. + * by a more sophisticated CookieStore implementation, e.g. a NetscapeCookieStore. *
  • * * @@ -201,10 +201,9 @@ public class CookieManager extends CookieHandler throw new IllegalArgumentException("Argument is null"); } - Map> cookieMap = new java.util.HashMap<>(); // if there's no default CookieStore, no way for us to get any cookie if (cookieJar == null) - return Collections.unmodifiableMap(cookieMap); + return Map.of(); boolean secureLink = "https".equalsIgnoreCase(uri.getScheme()); List cookies = new java.util.ArrayList<>(); @@ -244,8 +243,7 @@ public class CookieManager extends CookieHandler // apply sort rule (RFC 2965 sec. 3.3.4) List cookieHeader = sortByPath(cookies); - cookieMap.put("Cookie", cookieHeader); - return Collections.unmodifiableMap(cookieMap); + return Map.of("Cookie", cookieHeader); } public void diff --git a/jdk/src/java.base/share/classes/java/nio/file/FileTreeIterator.java b/jdk/src/java.base/share/classes/java/nio/file/FileTreeIterator.java index 63b4dc767d8..c748e32571b 100644 --- a/jdk/src/java.base/share/classes/java/nio/file/FileTreeIterator.java +++ b/jdk/src/java.base/share/classes/java/nio/file/FileTreeIterator.java @@ -31,11 +31,10 @@ import java.io.UncheckedIOException; import java.util.Arrays; import java.util.Iterator; import java.util.NoSuchElementException; -import java.util.Objects; import java.nio.file.FileTreeWalker.Event; /** - * An {@code Iterator to iterate over the nodes of a file tree. + * An {@code Iterator} to iterate over the nodes of a file tree. * *
    {@code
      *     try (FileTreeIterator iterator = new FileTreeIterator(start, maxDepth, options)) {
    @@ -62,7 +61,7 @@ class FileTreeIterator implements Iterator, Closeable {
          * @throws  SecurityException
          *          if the security manager denies access to the starting file
          * @throws  NullPointerException
    -     *          if {@code start} or {@code options} is {@ocde null} or
    +     *          if {@code start} or {@code options} is {@code null} or
          *          the options array contains a {@code null} element
          */
         FileTreeIterator(Path start, int maxDepth, FileVisitOption... options)
    diff --git a/jdk/src/java.base/share/classes/java/nio/file/FileTreeWalker.java b/jdk/src/java.base/share/classes/java/nio/file/FileTreeWalker.java
    index 13bb629807f..b7dc93ad0f5 100644
    --- a/jdk/src/java.base/share/classes/java/nio/file/FileTreeWalker.java
    +++ b/jdk/src/java.base/share/classes/java/nio/file/FileTreeWalker.java
    @@ -171,7 +171,7 @@ class FileTreeWalker implements Closeable {
          *          if {@code options} contains an element that is not a
          *          {@code FileVisitOption}
          * @throws  NullPointerException
    -     *          if {@code options} is {@ocde null} or the options
    +     *          if {@code options} is {@code null} or the options
          *          array contains a {@code null} element
          */
         FileTreeWalker(Collection options, int maxDepth) {
    diff --git a/jdk/src/java.base/share/classes/java/security/Signature.java b/jdk/src/java.base/share/classes/java/security/Signature.java
    index 7efa9c9a7e6..9bfe4667df6 100644
    --- a/jdk/src/java.base/share/classes/java/security/Signature.java
    +++ b/jdk/src/java.base/share/classes/java/security/Signature.java
    @@ -37,7 +37,6 @@ import java.nio.ByteBuffer;
     import java.security.Provider.Service;
     
     import javax.crypto.Cipher;
    -import javax.crypto.CipherSpi;
     import javax.crypto.IllegalBlockSizeException;
     import javax.crypto.BadPaddingException;
     import javax.crypto.NoSuchPaddingException;
    @@ -180,15 +179,12 @@ public abstract class Signature extends SignatureSpi {
         private static final String RSA_CIPHER = "RSA/ECB/PKCS1Padding";
     
         // all the services we need to lookup for compatibility with Cipher
    -    private static final List rsaIds = Arrays.asList(
    -        new ServiceId[] {
    -            new ServiceId("Signature", "NONEwithRSA"),
    -            new ServiceId("Cipher", "RSA/ECB/PKCS1Padding"),
    -            new ServiceId("Cipher", "RSA/ECB"),
    -            new ServiceId("Cipher", "RSA//PKCS1Padding"),
    -            new ServiceId("Cipher", "RSA"),
    -        }
    -    );
    +    private static final List rsaIds = List.of(
    +        new ServiceId("Signature", "NONEwithRSA"),
    +        new ServiceId("Cipher", "RSA/ECB/PKCS1Padding"),
    +        new ServiceId("Cipher", "RSA/ECB"),
    +        new ServiceId("Cipher", "RSA//PKCS1Padding"),
    +        new ServiceId("Cipher", "RSA"));
     
         /**
          * Returns a Signature object that implements the specified signature
    diff --git a/jdk/src/java.base/share/classes/java/time/Duration.java b/jdk/src/java.base/share/classes/java/time/Duration.java
    index e2c55a971ea..cacd3999a83 100644
    --- a/jdk/src/java.base/share/classes/java/time/Duration.java
    +++ b/jdk/src/java.base/share/classes/java/time/Duration.java
    @@ -88,8 +88,6 @@ import java.time.temporal.Temporal;
     import java.time.temporal.TemporalAmount;
     import java.time.temporal.TemporalUnit;
     import java.time.temporal.UnsupportedTemporalTypeException;
    -import java.util.Arrays;
    -import java.util.Collections;
     import java.util.List;
     import java.util.Objects;
     import java.util.regex.Matcher;
    @@ -578,8 +576,7 @@ public final class Duration
          * the simple initialization in Duration.
          */
         private static class DurationUnits {
    -        static final List UNITS =
    -                Collections.unmodifiableList(Arrays.asList(SECONDS, NANOS));
    +        static final List UNITS = List.of(SECONDS, NANOS);
         }
     
         //-----------------------------------------------------------------------
    diff --git a/jdk/src/java.base/share/classes/java/time/Period.java b/jdk/src/java.base/share/classes/java/time/Period.java
    index c7c04435262..e93d8a35d99 100644
    --- a/jdk/src/java.base/share/classes/java/time/Period.java
    +++ b/jdk/src/java.base/share/classes/java/time/Period.java
    @@ -83,8 +83,6 @@ import java.time.temporal.TemporalAmount;
     import java.time.temporal.TemporalQueries;
     import java.time.temporal.TemporalUnit;
     import java.time.temporal.UnsupportedTemporalTypeException;
    -import java.util.Arrays;
    -import java.util.Collections;
     import java.util.List;
     import java.util.Objects;
     import java.util.regex.Matcher;
    @@ -152,8 +150,7 @@ public final class Period
         /**
          * The set of supported units.
          */
    -    private static final List SUPPORTED_UNITS =
    -            Collections.unmodifiableList(Arrays.asList(YEARS, MONTHS, DAYS));
    +    private static final List SUPPORTED_UNITS = List.of(YEARS, MONTHS, DAYS);
     
         /**
          * The number of years.
    diff --git a/jdk/src/java.base/share/classes/java/time/ZoneId.java b/jdk/src/java.base/share/classes/java/time/ZoneId.java
    index bae99f601cc..5087888da4f 100644
    --- a/jdk/src/java.base/share/classes/java/time/ZoneId.java
    +++ b/jdk/src/java.base/share/classes/java/time/ZoneId.java
    @@ -76,14 +76,14 @@ import java.time.temporal.UnsupportedTemporalTypeException;
     import java.time.zone.ZoneRules;
     import java.time.zone.ZoneRulesException;
     import java.time.zone.ZoneRulesProvider;
    -import java.util.Collections;
    -import java.util.HashMap;
     import java.util.Locale;
     import java.util.Map;
     import java.util.Objects;
     import java.util.Set;
     import java.util.TimeZone;
     
    +import static java.util.Map.entry;
    +
     /**
      * A time-zone ID, such as {@code Europe/Paris}.
      * 

    @@ -220,39 +220,36 @@ public abstract class ZoneId implements Serializable { * * The map is unmodifiable. */ - public static final Map SHORT_IDS; - static { - Map map = new HashMap<>(64); - map.put("ACT", "Australia/Darwin"); - map.put("AET", "Australia/Sydney"); - map.put("AGT", "America/Argentina/Buenos_Aires"); - map.put("ART", "Africa/Cairo"); - map.put("AST", "America/Anchorage"); - map.put("BET", "America/Sao_Paulo"); - map.put("BST", "Asia/Dhaka"); - map.put("CAT", "Africa/Harare"); - map.put("CNT", "America/St_Johns"); - map.put("CST", "America/Chicago"); - map.put("CTT", "Asia/Shanghai"); - map.put("EAT", "Africa/Addis_Ababa"); - map.put("ECT", "Europe/Paris"); - map.put("IET", "America/Indiana/Indianapolis"); - map.put("IST", "Asia/Kolkata"); - map.put("JST", "Asia/Tokyo"); - map.put("MIT", "Pacific/Apia"); - map.put("NET", "Asia/Yerevan"); - map.put("NST", "Pacific/Auckland"); - map.put("PLT", "Asia/Karachi"); - map.put("PNT", "America/Phoenix"); - map.put("PRT", "America/Puerto_Rico"); - map.put("PST", "America/Los_Angeles"); - map.put("SST", "Pacific/Guadalcanal"); - map.put("VST", "Asia/Ho_Chi_Minh"); - map.put("EST", "-05:00"); - map.put("MST", "-07:00"); - map.put("HST", "-10:00"); - SHORT_IDS = Collections.unmodifiableMap(map); - } + public static final Map SHORT_IDS = Map.ofEntries( + entry("ACT", "Australia/Darwin"), + entry("AET", "Australia/Sydney"), + entry("AGT", "America/Argentina/Buenos_Aires"), + entry("ART", "Africa/Cairo"), + entry("AST", "America/Anchorage"), + entry("BET", "America/Sao_Paulo"), + entry("BST", "Asia/Dhaka"), + entry("CAT", "Africa/Harare"), + entry("CNT", "America/St_Johns"), + entry("CST", "America/Chicago"), + entry("CTT", "Asia/Shanghai"), + entry("EAT", "Africa/Addis_Ababa"), + entry("ECT", "Europe/Paris"), + entry("IET", "America/Indiana/Indianapolis"), + entry("IST", "Asia/Kolkata"), + entry("JST", "Asia/Tokyo"), + entry("MIT", "Pacific/Apia"), + entry("NET", "Asia/Yerevan"), + entry("NST", "Pacific/Auckland"), + entry("PLT", "Asia/Karachi"), + entry("PNT", "America/Phoenix"), + entry("PRT", "America/Puerto_Rico"), + entry("PST", "America/Los_Angeles"), + entry("SST", "Pacific/Guadalcanal"), + entry("VST", "Asia/Ho_Chi_Minh"), + entry("EST", "-05:00"), + entry("MST", "-07:00"), + entry("HST", "-10:00") + ); /** * Serialization version. */ diff --git a/jdk/src/java.base/share/classes/java/time/chrono/ChronoPeriodImpl.java b/jdk/src/java.base/share/classes/java/time/chrono/ChronoPeriodImpl.java index 911144d5b04..646af14d05a 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/ChronoPeriodImpl.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/ChronoPeriodImpl.java @@ -77,8 +77,6 @@ import java.time.temporal.TemporalQueries; import java.time.temporal.TemporalUnit; import java.time.temporal.UnsupportedTemporalTypeException; import java.time.temporal.ValueRange; -import java.util.Arrays; -import java.util.Collections; import java.util.List; import java.util.Objects; @@ -105,8 +103,7 @@ final class ChronoPeriodImpl /** * The set of supported units. */ - private static final List SUPPORTED_UNITS = - Collections.unmodifiableList(Arrays.asList(YEARS, MONTHS, DAYS)); + private static final List SUPPORTED_UNITS = List.of(YEARS, MONTHS, DAYS); /** * The chronology. diff --git a/jdk/src/java.base/share/classes/java/time/chrono/HijrahChronology.java b/jdk/src/java.base/share/classes/java/time/chrono/HijrahChronology.java index ebe4e8a29d4..d61c2333303 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/HijrahChronology.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/HijrahChronology.java @@ -59,10 +59,7 @@ package java.time.chrono; import static java.time.temporal.ChronoField.EPOCH_DAY; -import java.io.File; -import java.io.FileInputStream; import java.io.FilePermission; -import java.io.IOException; import java.io.InputStream; import java.io.InvalidObjectException; import java.io.ObjectInputStream; @@ -83,7 +80,6 @@ import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.Objects; import java.util.Properties; import sun.util.logging.PlatformLogger; @@ -512,7 +508,7 @@ public final class HijrahChronology extends AbstractChronology implements Serial @Override public List eras() { - return Arrays.asList(HijrahEra.values()); + return List.of(HijrahEra.values()); } //----------------------------------------------------------------------- diff --git a/jdk/src/java.base/share/classes/java/time/chrono/IsoChronology.java b/jdk/src/java.base/share/classes/java/time/chrono/IsoChronology.java index 7ce8e4ba21a..4919b3d7d3a 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/IsoChronology.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/IsoChronology.java @@ -90,7 +90,6 @@ import java.time.temporal.ChronoField; import java.time.temporal.TemporalAccessor; import java.time.temporal.TemporalField; import java.time.temporal.ValueRange; -import java.util.Arrays; import java.util.List; import java.util.Locale; import java.util.Map; @@ -492,7 +491,7 @@ public final class IsoChronology extends AbstractChronology implements Serializa @Override public List eras() { - return Arrays.asList(IsoEra.values()); + return List.of(IsoEra.values()); } //----------------------------------------------------------------------- diff --git a/jdk/src/java.base/share/classes/java/time/chrono/JapaneseChronology.java b/jdk/src/java.base/share/classes/java/time/chrono/JapaneseChronology.java index 2bd38c8d755..4478c4c7de1 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/JapaneseChronology.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/JapaneseChronology.java @@ -81,7 +81,6 @@ import java.time.temporal.TemporalAdjusters; import java.time.temporal.TemporalField; import java.time.temporal.UnsupportedTemporalTypeException; import java.time.temporal.ValueRange; -import java.util.Arrays; import java.util.Calendar; import java.util.List; import java.util.Locale; @@ -379,7 +378,7 @@ public final class JapaneseChronology extends AbstractChronology implements Seri @Override public List eras() { - return Arrays.asList(JapaneseEra.values()); + return List.of(JapaneseEra.values()); } JapaneseEra getCurrentEra() { diff --git a/jdk/src/java.base/share/classes/java/time/chrono/MinguoChronology.java b/jdk/src/java.base/share/classes/java/time/chrono/MinguoChronology.java index 8159adc0ac5..fd6fdc3e8cd 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/MinguoChronology.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/MinguoChronology.java @@ -72,7 +72,6 @@ import java.time.temporal.ChronoField; import java.time.temporal.TemporalAccessor; import java.time.temporal.TemporalField; import java.time.temporal.ValueRange; -import java.util.Arrays; import java.util.List; import java.util.Locale; import java.util.Map; @@ -306,7 +305,7 @@ public final class MinguoChronology extends AbstractChronology implements Serial @Override public List eras() { - return Arrays.asList(MinguoEra.values()); + return List.of(MinguoEra.values()); } //----------------------------------------------------------------------- diff --git a/jdk/src/java.base/share/classes/java/time/chrono/ThaiBuddhistChronology.java b/jdk/src/java.base/share/classes/java/time/chrono/ThaiBuddhistChronology.java index 6412c9dab15..c6938b2c530 100644 --- a/jdk/src/java.base/share/classes/java/time/chrono/ThaiBuddhistChronology.java +++ b/jdk/src/java.base/share/classes/java/time/chrono/ThaiBuddhistChronology.java @@ -342,7 +342,7 @@ public final class ThaiBuddhistChronology extends AbstractChronology implements @Override public List eras() { - return Arrays.asList(ThaiBuddhistEra.values()); + return List.of(ThaiBuddhistEra.values()); } //----------------------------------------------------------------------- diff --git a/jdk/src/java.base/share/classes/java/time/format/DateTimeFormatter.java b/jdk/src/java.base/share/classes/java/time/format/DateTimeFormatter.java index ec5fd9c8086..a3f903a7d9a 100644 --- a/jdk/src/java.base/share/classes/java/time/format/DateTimeFormatter.java +++ b/jdk/src/java.base/share/classes/java/time/format/DateTimeFormatter.java @@ -1685,6 +1685,7 @@ public final class DateTimeFormatter { public DateTimeFormatter withResolverFields(TemporalField... resolverFields) { Set fields = null; if (resolverFields != null) { + // Set.of cannot be used because it is hostile to nulls and duplicate elements fields = Collections.unmodifiableSet(new HashSet<>(Arrays.asList(resolverFields))); } if (Objects.equals(this.resolverFields, fields)) { diff --git a/jdk/src/java.base/share/classes/java/time/zone/ZoneOffsetTransition.java b/jdk/src/java.base/share/classes/java/time/zone/ZoneOffsetTransition.java index c1568e46364..94264f32cce 100644 --- a/jdk/src/java.base/share/classes/java/time/zone/ZoneOffsetTransition.java +++ b/jdk/src/java.base/share/classes/java/time/zone/ZoneOffsetTransition.java @@ -387,9 +387,9 @@ public final class ZoneOffsetTransition */ List getValidOffsets() { if (isGap()) { - return Collections.emptyList(); + return List.of(); } - return Arrays.asList(getOffsetBefore(), getOffsetAfter()); + return List.of(getOffsetBefore(), getOffsetAfter()); } //----------------------------------------------------------------------- diff --git a/jdk/src/java.base/share/classes/java/time/zone/ZoneRules.java b/jdk/src/java.base/share/classes/java/time/zone/ZoneRules.java index f6154857b8d..ed2330f38ef 100644 --- a/jdk/src/java.base/share/classes/java/time/zone/ZoneRules.java +++ b/jdk/src/java.base/share/classes/java/time/zone/ZoneRules.java @@ -303,7 +303,6 @@ public final class ZoneRules implements Serializable { * Creates an instance of ZoneRules that has fixed zone rules. * * @param offset the offset this fixed zone rules is based on, not null - * @return the zone rules, not null * @see #isFixedOffset() */ private ZoneRules(ZoneOffset offset) { @@ -970,7 +969,7 @@ public final class ZoneRules implements Serializable { * @return an immutable list of transition rules, not null */ public List getTransitionRules() { - return Collections.unmodifiableList(Arrays.asList(lastRules)); + return List.of(lastRules); } /** diff --git a/jdk/src/java.base/share/classes/java/util/ResourceBundle.java b/jdk/src/java.base/share/classes/java/util/ResourceBundle.java index bc7aaae063e..1d84e2dee6b 100644 --- a/jdk/src/java.base/share/classes/java/util/ResourceBundle.java +++ b/jdk/src/java.base/share/classes/java/util/ResourceBundle.java @@ -2491,34 +2491,29 @@ public abstract class ResourceBundle { /** * The default format List, which contains the strings * "java.class" and "java.properties", in - * this order. This List is {@linkplain - * Collections#unmodifiableList(List) unmodifiable}. + * this order. This List is unmodifiable. * * @see #getFormats(String) */ public static final List FORMAT_DEFAULT - = Collections.unmodifiableList(Arrays.asList("java.class", - "java.properties")); + = List.of("java.class", "java.properties"); /** * The class-only format List containing - * "java.class". This List is {@linkplain - * Collections#unmodifiableList(List) unmodifiable}. + * "java.class". This List is unmodifiable. * * @see #getFormats(String) */ - public static final List FORMAT_CLASS - = Collections.unmodifiableList(Arrays.asList("java.class")); + public static final List FORMAT_CLASS = List.of("java.class"); /** * The properties-only format List containing - * "java.properties". This List is - * {@linkplain Collections#unmodifiableList(List) unmodifiable}. + * "java.properties". This List is unmodifiable. * * @see #getFormats(String) */ public static final List FORMAT_PROPERTIES - = Collections.unmodifiableList(Arrays.asList("java.properties")); + = List.of("java.properties"); /** * The time-to-live constant for not caching loaded resource bundle diff --git a/jdk/src/java.base/share/classes/java/util/stream/Collectors.java b/jdk/src/java.base/share/classes/java/util/stream/Collectors.java index 018bb5fc1b6..fd7b0a477fa 100644 --- a/jdk/src/java.base/share/classes/java/util/stream/Collectors.java +++ b/jdk/src/java.base/share/classes/java/util/stream/Collectors.java @@ -27,7 +27,6 @@ package java.util.stream; import java.util.AbstractMap; import java.util.AbstractSet; import java.util.ArrayList; -import java.util.Arrays; import java.util.Collection; import java.util.Collections; import java.util.Comparator; @@ -1720,12 +1719,12 @@ public final class Collectors { @Override public Set> entrySet() { - return new AbstractSet>() { + return new AbstractSet<>() { @Override public Iterator> iterator() { Map.Entry falseEntry = new SimpleImmutableEntry<>(false, forFalse); Map.Entry trueEntry = new SimpleImmutableEntry<>(true, forTrue); - return Arrays.asList(falseEntry, trueEntry).iterator(); + return List.of(falseEntry, trueEntry).iterator(); } @Override From 71c0fe87109b226a92cd752b21a08125d6d6665f Mon Sep 17 00:00:00 2001 From: Steve Drach Date: Wed, 12 Oct 2016 14:31:17 -0700 Subject: [PATCH 24/43] 8166460: jdk/internal/util/jar/TestVersionedStream gets Assertion error Reviewed-by: psandoz --- .../util/jar/TestVersionedStream.java | 145 ++++++++++-------- 1 file changed, 81 insertions(+), 64 deletions(-) diff --git a/jdk/test/jdk/internal/util/jar/TestVersionedStream.java b/jdk/test/jdk/internal/util/jar/TestVersionedStream.java index 12e45f03b77..5dbef938752 100644 --- a/jdk/test/jdk/internal/util/jar/TestVersionedStream.java +++ b/jdk/test/jdk/internal/util/jar/TestVersionedStream.java @@ -25,13 +25,14 @@ * @test * @bug 8163798 * @summary basic tests for multi-release jar versioned streams + * @library /lib/testlibrary * @modules jdk.jartool/sun.tools.jar java.base/jdk.internal.util.jar + * @build jdk.testlibrary.FileUtils * @run testng TestVersionedStream */ import org.testng.Assert; import org.testng.annotations.AfterClass; -import org.testng.annotations.BeforeClass; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; @@ -40,29 +41,31 @@ import java.io.IOException; import java.io.InputStream; import java.io.UncheckedIOException; import java.net.URI; -import java.nio.file.FileVisitResult; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; -import java.nio.file.SimpleFileVisitor; -import java.nio.file.attribute.BasicFileAttributes; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; +import java.util.Iterator; +import java.util.LinkedHashSet; import java.util.List; import java.util.Map; +import java.util.Set; import java.util.jar.JarEntry; import java.util.jar.JarFile; import java.util.stream.Collectors; import java.util.stream.Stream; import java.util.zip.ZipFile; -public class TestVersionedStream { - private String userdir; +import jdk.testlibrary.FileUtils; - @BeforeClass - public void initialize() { - userdir = System.getProperty("user.dir", "."); +public class TestVersionedStream { + private final Path userdir; + private final Set unversionedEntryNames; + + public TestVersionedStream() throws IOException { + userdir = Paths.get(System.getProperty("user.dir", ".")); // These are not real class files even though they end with .class. // They are resource files so jar tool validation won't reject them. @@ -70,91 +73,103 @@ public class TestVersionedStream { // could be in a concealed package if this was a modular multi-release // jar. createFiles( + "base/p/Bar.class", "base/p/Foo.class", "base/p/Main.class", "v9/p/Foo.class", "v10/p/Foo.class", "v10/q/Bar.class", + "v11/p/Bar.class", "v11/p/Foo.class" ); - jar("cf mmr.jar -C base . --release 9 -C v9 . --release 10 -C v10 . --release 11 -C v11 ."); + jar("cf mmr.jar -C base . --release 9 -C v9 . " + + "--release 10 -C v10 . --release 11 -C v11 ."); System.out.println("Contents of mmr.jar\n======="); - jar("tf mmr.jar"); + + try(JarFile jf = new JarFile("mmr.jar")) { + unversionedEntryNames = jf.stream() + .map(je -> je.getName()) + .peek(System.out::println) + .map(nm -> nm.startsWith("META-INF/versions/") + ? nm.replaceFirst("META-INF/versions/\\d+/", "") + : nm) + .collect(Collectors.toCollection(LinkedHashSet::new)); + } + System.out.println("======="); } @AfterClass public void close() throws IOException { - Path root = Paths.get(userdir); - Files.walkFileTree(root, new SimpleFileVisitor<>() { - @Override - public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException { - Files.delete(file); - return FileVisitResult.CONTINUE; - } - - @Override - public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException { - if (!dir.equals(root)) { - Files.delete(dir); - } - return FileVisitResult.CONTINUE; - } - }); + Files.walk(userdir, 1) + .filter(p -> !p.equals(userdir)) + .forEach(p -> { + try { + if (Files.isDirectory(p)) { + FileUtils.deleteFileTreeWithRetry(p); + } else { + FileUtils.deleteFileIfExistsWithRetry(p); + } + } catch (IOException x) { + throw new UncheckedIOException(x); + } + }); } @DataProvider public Object[][] data() { - List p = List.of( - "META-INF/", - "META-INF/MANIFEST.MF", - "p/", - "p/Foo.class", - "p/Main.class" - ); - List q = List.of( - "META-INF/", - "META-INF/MANIFEST.MF", - "p/", - "p/Foo.class", - "p/Main.class", - "q/", - "q/Bar.class" - ); - Runtime.Version rt = JarFile.runtimeVersion(); return new Object[][] { - {Runtime.Version.parse("8"), p}, - {Runtime.Version.parse("9"), p}, - {Runtime.Version.parse("10"), q}, - {Runtime.Version.parse("11"), q}, - {JarFile.baseVersion(), p}, - {rt, rt.major() > 9 ? q : p} + {Runtime.Version.parse("8")}, + {Runtime.Version.parse("9")}, + {Runtime.Version.parse("10")}, + {Runtime.Version.parse("11")}, + {JarFile.baseVersion()}, + {JarFile.runtimeVersion()} }; } @Test(dataProvider="data") - public void test(Runtime.Version version, List names) throws Exception { + public void test(Runtime.Version version) throws Exception { try (JarFile jf = new JarFile(new File("mmr.jar"), false, ZipFile.OPEN_READ, version); - Stream jes = jdk.internal.util.jar.VersionedStream.stream(jf)) + Stream jes = jdk.internal.util.jar.VersionedStream.stream(jf)) { Assert.assertNotNull(jes); - List entries = jes.collect(Collectors.toList()); + // put versioned entries in list so we can reuse them + List versionedEntries = jes.collect(Collectors.toList()); - // verify the correct order - List enames = entries.stream() - .map(je -> je.getName()) - .collect(Collectors.toList()); - Assert.assertEquals(enames, names); + Assert.assertTrue(versionedEntries.size() > 0); + + // also keep the names + List versionedNames = new ArrayList<>(versionedEntries.size()); + + // verify the correct order while building enames + Iterator allIt = unversionedEntryNames.iterator(); + Iterator verIt = versionedEntries.iterator(); + boolean match = false; + + while (verIt.hasNext()) { + match = false; + if (!allIt.hasNext()) break; + String name = verIt.next().getName(); + versionedNames.add(name); + while (allIt.hasNext()) { + if (name.equals(allIt.next())) { + match = true; + break; + } + } + } + if (!match) { + Assert.fail("versioned entries not in same order as unversioned entries"); + } // verify the contents Map contents = new HashMap<>(); + contents.put("p/Bar.class", "base/p/Bar.class\n"); contents.put("p/Main.class", "base/p/Main.class\n"); - if (version.major() > 9) { - contents.put("q/Bar.class", "v10/q/Bar.class\n"); - } switch (version.major()) { case 8: contents.put("p/Foo.class", "base/p/Foo.class\n"); @@ -164,9 +179,12 @@ public class TestVersionedStream { break; case 10: contents.put("p/Foo.class", "v10/p/Foo.class\n"); + contents.put("q/Bar.class", "v10/q/Bar.class\n"); break; case 11: + contents.put("p/Bar.class", "v11/p/Bar.class\n"); contents.put("p/Foo.class", "v11/p/Foo.class\n"); + contents.put("q/Bar.class", "v10/q/Bar.class\n"); break; default: Assert.fail("Test out of date, please add more cases"); @@ -174,9 +192,9 @@ public class TestVersionedStream { contents.entrySet().stream().forEach(e -> { String name = e.getKey(); - int i = enames.indexOf(name); + int i = versionedNames.indexOf(name); Assert.assertTrue(i != -1, name + " not in enames"); - JarEntry je = entries.get(i); + JarEntry je = versionedEntries.get(i); try (InputStream is = jf.getInputStream(je)) { String s = new String(is.readAllBytes()); Assert.assertTrue(s.endsWith(e.getValue()), s); @@ -210,5 +228,4 @@ public class TestVersionedStream { new sun.tools.jar.Main(System.out, System.err, "jar") .run(args.split(" +")); } - } From 44a7c1b644915816621365350f01d190b22a7b8d Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Wed, 12 Oct 2016 15:41:00 -0700 Subject: [PATCH 25/43] 8164689: Retrofit jar, jlink, jmod as a ToolProvider Reviewed-by: alanb, lancea --- .../classes/java/util/spi/ToolProvider.java | 32 ++++++++------- .../share/classes/module-info.java | 2 + .../sun/tools/jar/GNUStyleOptions.java | 9 +++-- .../sun/tools/jar/JarToolProvider.java | 40 +++++++++++++++++++ .../share/classes/sun/tools/jar/Main.java | 14 +++++-- .../jdk/tools/jlink/internal/JlinkTask.java | 5 ++- .../jdk/tools/jlink/internal/Main.java | 19 +++++++-- .../classes/jdk/tools/jmod/JmodTask.java | 5 ++- .../share/classes/jdk/tools/jmod/Main.java | 18 +++++++-- .../jdk.jlink/share/classes/module-info.java | 3 ++ .../module/ModuleReader/ModuleReaderTest.java | 10 +++-- jdk/test/tools/jar/ChangeDir.java | 14 +++++-- jdk/test/tools/jar/InputFilesTest.java | 12 ++++-- jdk/test/tools/jar/JarBackSlash.java | 17 ++++---- jdk/test/tools/jar/JarEntryTime.java | 16 ++++---- jdk/test/tools/jar/UpdateJar.java | 12 ++++-- jdk/test/tools/jar/UpdateManifest.java | 37 +++++++++-------- jdk/test/tools/jar/index/MetaInf.java | 10 +++-- jdk/test/tools/jlink/JLinkTest.java | 15 +++++-- jdk/test/tools/jlink/basic/BasicTest.java | 21 +++++++--- jdk/test/tools/jmod/JmodNegativeTest.java | 12 ++++-- jdk/test/tools/jmod/JmodTest.java | 12 ++++-- jdk/test/tools/jmod/hashes/HashesTest.java | 10 +++-- .../launcher/modules/basic/BasicTest.java | 31 ++++++++------ .../launcher/modules/dryrun/DryRunTest.java | 18 +++++---- jdk/test/tools/lib/tests/JImageGenerator.java | 17 ++++++-- 26 files changed, 287 insertions(+), 124 deletions(-) create mode 100644 jdk/src/jdk.jartool/share/classes/sun/tools/jar/JarToolProvider.java diff --git a/jdk/src/java.base/share/classes/java/util/spi/ToolProvider.java b/jdk/src/java.base/share/classes/java/util/spi/ToolProvider.java index 850f1df24ee..1d96cd1f326 100644 --- a/jdk/src/java.base/share/classes/java/util/spi/ToolProvider.java +++ b/jdk/src/java.base/share/classes/java/util/spi/ToolProvider.java @@ -56,8 +56,8 @@ public interface ToolProvider { /** * Returns the name of this tool provider. * - * @apiNote It is recommended that the name be the same as would be used on - * the command line: for example, "javac", "jar", "jlink". + * @apiNote It is recommended that the name be the same as would be + * used on the command line: for example, "javac", "jar", "jlink". * * @return the name of this tool provider */ @@ -67,12 +67,13 @@ public interface ToolProvider { * Runs an instance of the tool, returning zero for a successful run. * Any non-zero return value indicates a tool-specific error during the * execution. + * * Two streams should be provided, for "expected" output, and for any * error messages. If it is not necessary to distinguish the output, * the same stream may be used for both. * * @apiNote The interpretation of the arguments will be specific to - * each tool. + * each tool. * * @param out a stream to which "expected" output should be written * @@ -81,12 +82,13 @@ public interface ToolProvider { * @param args the command-line arguments for the tool * * @return the result of executing the tool. - * A return value of 0 means the tool did not encounter any errors; - * any other value indicates that at least one error occurred during - * execution. + * A return value of 0 means the tool did not encounter any errors; + * any other value indicates that at least one error occurred + * during execution. * * @throws NullPointerException if any of the arguments are {@code null}, - * or if there are any {@code null} values in the {@code args} array + * or if there are any {@code null} values in the {@code args} + * array */ int run(PrintWriter out, PrintWriter err, String... args); @@ -94,16 +96,17 @@ public interface ToolProvider { * Runs an instance of the tool, returning zero for a successful run. * Any non-zero return value indicates a tool-specific error during the * execution. + * * Two streams should be provided, for "expected" output, and for any * error messages. If it is not necessary to distinguish the output, * the same stream may be used for both. * * @apiNote The interpretation of the arguments will be specific to - * each tool. + * each tool. * * @implNote This implementation wraps the {@code out} and {@code err} - * streams within {@link PrintWriter}s, and then calls - * {@link run(PrintWriter, PrintWriter, String[])}. + * streams within {@link PrintWriter}s, and then calls + * {@link #run(PrintWriter, PrintWriter, String[])}. * * @param out a stream to which "expected" output should be written * @@ -112,12 +115,13 @@ public interface ToolProvider { * @param args the command-line arguments for the tool * * @return the result of executing the tool. - * A return value of 0 means the tool did not encounter any errors; - * any other value indicates that at least one error occurred during - * execution. + * A return value of 0 means the tool did not encounter any errors; + * any other value indicates that at least one error occurred + * during execution. * * @throws NullPointerException if any of the arguments are {@code null}, - * or if there are any {@code null} values in the {@code args} array + * or if there are any {@code null} values in the {@code args} + * array */ default int run(PrintStream out, PrintStream err, String... args) { Objects.requireNonNull(out); diff --git a/jdk/src/jdk.jartool/share/classes/module-info.java b/jdk/src/jdk.jartool/share/classes/module-info.java index cbf703263d4..536ca81b684 100644 --- a/jdk/src/jdk.jartool/share/classes/module-info.java +++ b/jdk/src/jdk.jartool/share/classes/module-info.java @@ -26,5 +26,7 @@ module jdk.jartool { exports com.sun.jarsigner; exports jdk.security.jarsigner; + + provides java.util.spi.ToolProvider with sun.tools.jar.JarToolProvider; } diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java index 165a424d9ca..c0b58d95c46 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java @@ -27,6 +27,7 @@ package sun.tools.jar; import java.io.File; import java.io.PrintStream; +import java.io.PrintWriter; import java.lang.module.ModuleFinder; import java.lang.module.ModuleDescriptor.Version; import java.nio.file.Path; @@ -289,7 +290,7 @@ class GNUStyleOptions { throw new BadArgs("error.unrecognized.option", name).showUsage(true); } - static void printHelp(PrintStream out) { + static void printHelp(PrintWriter out) { out.format("%s%n", Main.getMsg("main.help.preopt")); for (OptionType type : OptionType.values()) { boolean typeHeadingWritten = false; @@ -312,16 +313,16 @@ class GNUStyleOptions { out.format("%n%s%n%n", Main.getMsg("main.help.postopt")); } - static void printCompatHelp(PrintStream out) { + static void printCompatHelp(PrintWriter out) { out.format("%s%n", Main.getMsg("usage.compat")); } - static void printUsageSummary(PrintStream out) { + static void printUsageSummary(PrintWriter out) { out.format("%s%n", Main.getMsg("main.usage.summary")); out.format("%s%n", Main.getMsg("main.usage.summary.try")); } - static void printVersion(PrintStream out) { + static void printVersion(PrintWriter out) { out.format("%s %s%n", "jar", System.getProperty("java.version")); } } diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/JarToolProvider.java b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/JarToolProvider.java new file mode 100644 index 00000000000..959db36a2f1 --- /dev/null +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/JarToolProvider.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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 sun.tools.jar; + +import java.io.PrintWriter; +import java.util.spi.ToolProvider; + +public class JarToolProvider implements ToolProvider { + public String name() { + return "jar"; + } + + public int run(PrintWriter out, PrintWriter err, String... args) { + boolean ok = new Main(out, err, name()).run(args); + return ok ? 0 : 1; + } +} diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java index 41ccfe9f774..6aa65550140 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java @@ -76,7 +76,7 @@ import static java.nio.file.StandardCopyOption.REPLACE_EXISTING; public class Main { String program; - PrintStream out, err; + PrintWriter out, err; String fname, mname, ename; String zname = ""; String rootjar = null; @@ -189,9 +189,9 @@ class Main { USAGE_SUMMARY(GNUStyleOptions::printUsageSummary), VERSION(GNUStyleOptions::printVersion); - private Consumer printFunction; - Info(Consumer f) { this.printFunction = f; } - void print(PrintStream out) { printFunction.accept(out); } + private Consumer printFunction; + Info(Consumer f) { this.printFunction = f; } + void print(PrintWriter out) { printFunction.accept(out); } }; Info info; @@ -252,6 +252,12 @@ class Main { } public Main(PrintStream out, PrintStream err, String program) { + this.out = new PrintWriter(out, true); + this.err = new PrintWriter(err, true); + this.program = program; + } + + public Main(PrintWriter out, PrintWriter err, String program) { this.out = out; this.err = err; this.program = program; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java index dfecf9e0c3a..8fa165c1940 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java @@ -153,7 +153,7 @@ public class JlinkTask { = taskHelper.newOptionsHelper(JlinkTask.class, recognizedOptions); private PrintWriter log; - void setLog(PrintWriter out) { + void setLog(PrintWriter out, PrintWriter err) { log = out; taskHelper.setLog(log); } @@ -182,7 +182,8 @@ public class JlinkTask { int run(String[] args) { if (log == null) { - setLog(new PrintWriter(System.out, true)); + setLog(new PrintWriter(System.out, true), + new PrintWriter(System.err, true)); } try { optionsHelper.handleOptions(this, args); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Main.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Main.java index 651480de253..d9f968d4d78 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Main.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Main.java @@ -26,6 +26,7 @@ package jdk.tools.jlink.internal; import java.io.*; +import java.util.spi.ToolProvider; public class Main { public static void main(String... args) throws Exception { @@ -34,17 +35,27 @@ public class Main { System.exit(rc); } - /** * Entry point that does not call System.exit. * - * @param args command line arguments * @param out output stream + * @param err error output stream + * @param args command line arguments * @return an exit code. 0 means success, non-zero means an error occurred. */ - public static int run(String[] args, PrintWriter out) { + public static int run(PrintWriter out, PrintWriter err, String... args) { JlinkTask t = new JlinkTask(); - t.setLog(out); + t.setLog(out, err); return t.run(args); } + + public static class JlinkToolProvider implements ToolProvider { + public String name() { + return "jlink"; + } + + public int run(PrintWriter out, PrintWriter err, String... args) { + return Main.run(out, err, args); + } + } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/JmodTask.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/JmodTask.java index 6c23ce01bba..e37d9968800 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/JmodTask.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/JmodTask.java @@ -32,6 +32,7 @@ import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.PrintStream; +import java.io.PrintWriter; import java.io.UncheckedIOException; import java.lang.module.Configuration; import java.lang.module.ModuleReader; @@ -136,8 +137,8 @@ public class JmodTask { private static final String MODULE_INFO = "module-info.class"; private Options options; - private PrintStream out = System.out; - void setLog(PrintStream out) { + private PrintWriter out = new PrintWriter(System.out, true); + void setLog(PrintWriter out, PrintWriter err) { this.out = out; } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/Main.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/Main.java index 227f9948e65..1d069607d05 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/Main.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/Main.java @@ -26,6 +26,7 @@ package jdk.tools.jmod; import java.io.*; +import java.util.spi.ToolProvider; public class Main { public static void main(String... args) throws Exception { @@ -37,13 +38,24 @@ public class Main { /** * Entry point that does not call System.exit. * - * @param args command line arguments * @param out output stream + * @param err error output stream + * @param args command line arguments * @return an exit code. 0 means success, non-zero means an error occurred. */ - public static int run(String[] args, PrintStream out) { + public static int run(PrintWriter out, PrintWriter err, String... args) { JmodTask t = new JmodTask(); - t.setLog(out); + t.setLog(out, err); return t.run(args); } + + public static class JmodToolProvider implements ToolProvider { + public String name() { + return "jmod"; + } + + public int run(PrintWriter out, PrintWriter err, String... args) { + return Main.run(out, err, args); + } + } } diff --git a/jdk/src/jdk.jlink/share/classes/module-info.java b/jdk/src/jdk.jlink/share/classes/module-info.java index 0b1995129f2..2564412d59c 100644 --- a/jdk/src/jdk.jlink/share/classes/module-info.java +++ b/jdk/src/jdk.jlink/share/classes/module-info.java @@ -31,6 +31,9 @@ module jdk.jlink { uses jdk.tools.jlink.plugin.Plugin; + provides java.util.spi.ToolProvider with jdk.tools.jmod.Main.JmodToolProvider; + provides java.util.spi.ToolProvider with jdk.tools.jlink.internal.Main.JlinkToolProvider; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.FileCopierPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.StripDebugPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ExcludePlugin; diff --git a/jdk/test/java/lang/module/ModuleReader/ModuleReaderTest.java b/jdk/test/java/lang/module/ModuleReader/ModuleReaderTest.java index cdeb61b899a..139a56871b9 100644 --- a/jdk/test/java/lang/module/ModuleReader/ModuleReaderTest.java +++ b/jdk/test/java/lang/module/ModuleReader/ModuleReaderTest.java @@ -25,8 +25,8 @@ * @test * @library /lib/testlibrary * @modules java.base/jdk.internal.module - * jdk.jlink/jdk.tools.jmod * jdk.compiler + * jdk.jlink * @build ModuleReaderTest CompilerUtils JarUtils * @run testng ModuleReaderTest * @summary Basic tests for java.lang.module.ModuleReader @@ -48,6 +48,7 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.util.Arrays; import java.util.Optional; +import java.util.spi.ToolProvider; import jdk.internal.module.ConfigurableModuleFinder; import jdk.internal.module.ConfigurableModuleFinder.Phase; @@ -196,8 +197,11 @@ public class ModuleReaderTest { String cp = MODS_DIR.resolve(TEST_MODULE).toString(); String jmod = dir.resolve("m.jmod").toString(); String[] args = { "create", "--class-path", cp, jmod }; - jdk.tools.jmod.JmodTask task = new jdk.tools.jmod.JmodTask(); - assertEquals(task.run(args), 0); + ToolProvider jmodTool = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); + assertEquals(jmodTool.run(System.out, System.out, args), 0); test(dir); } diff --git a/jdk/test/tools/jar/ChangeDir.java b/jdk/test/tools/jar/ChangeDir.java index 7d3516bcba7..374b481bd77 100644 --- a/jdk/test/tools/jar/ChangeDir.java +++ b/jdk/test/tools/jar/ChangeDir.java @@ -24,7 +24,7 @@ /** * @test * @bug 4806786 8023113 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary jar -C doesn't ignore multiple // in path */ @@ -32,10 +32,15 @@ import java.io.*; import java.nio.file.*; import java.util.*; import java.util.jar.*; +import java.util.spi.ToolProvider; import java.util.stream.Stream; -import sun.tools.jar.Main; public class ChangeDir { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + private final static String jarName = "test.jar"; private final static String fileName = "hello.txt"; @@ -88,8 +93,9 @@ public class ChangeDir { argList.add(topDir.toString() + sep + "a" + sep + sep + "b"); // Note double 'sep' is intentional argList.add(fileName); - Main jarTool = new Main(System.out, System.err, "jar"); - if (!jarTool.run(argList.toArray(new String[argList.size()]))) { + int rc = JAR_TOOL.run(System.out, System.err, + argList.toArray(new String[argList.size()])); + if (rc != 0) { fail("Could not create jar file."); } diff --git a/jdk/test/tools/jar/InputFilesTest.java b/jdk/test/tools/jar/InputFilesTest.java index 7feaa533f93..ac5b3b29f94 100644 --- a/jdk/test/tools/jar/InputFilesTest.java +++ b/jdk/test/tools/jar/InputFilesTest.java @@ -29,7 +29,7 @@ * duplicates that sometimes cause exceptions and other times do not, * demonstrating identical behavior to JDK 8 jar tool. * @library /lib/testlibrary - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @build jdk.testlibrary.FileUtils * @run testng InputFilesTest */ @@ -47,12 +47,18 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.util.Arrays; +import java.util.spi.ToolProvider; import java.util.stream.Stream; import java.util.zip.ZipException; import jdk.testlibrary.FileUtils; public class InputFilesTest { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + private final String nl = System.lineSeparator(); private final ByteArrayOutputStream baos = new ByteArrayOutputStream(); private final PrintStream out = new PrintStream(baos); @@ -195,9 +201,9 @@ public class InputFilesTest { PrintStream err = new PrintStream(baes); PrintStream saveErr = System.err; System.setErr(err); - boolean ok = new sun.tools.jar.Main(out, err, "jar").run(cmdline.split(" +")); + int rc = JAR_TOOL.run(out, err, cmdline.split(" +")); System.setErr(saveErr); - if (!ok) { + if (rc != 0) { String s = baes.toString(); if (s.startsWith("java.util.zip.ZipException: duplicate entry: ")) { throw new ZipException(s); diff --git a/jdk/test/tools/jar/JarBackSlash.java b/jdk/test/tools/jar/JarBackSlash.java index 565606b8f3f..74c561d1fe6 100644 --- a/jdk/test/tools/jar/JarBackSlash.java +++ b/jdk/test/tools/jar/JarBackSlash.java @@ -28,7 +28,7 @@ /* * @test * @bug 7201156 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary jar tool fails to convert file separation characters for list and extract * @author Sean Chou */ @@ -43,10 +43,13 @@ import java.util.ArrayList; import java.util.List; import java.util.jar.JarEntry; import java.util.jar.JarOutputStream; - -import sun.tools.jar.Main; +import java.util.spi.ToolProvider; public class JarBackSlash { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); // used construct an entry JarBackSlash/dir/file.txt private static String JARBACKSLASH = "JarBackSlash"; @@ -78,8 +81,8 @@ public class JarBackSlash { PipedInputStream pipedInput = new PipedInputStream(pipedOutput); PrintStream out = new PrintStream(pipedOutput); - Main jarTool = new Main(out, System.err, "jar"); - if (!jarTool.run(jarArgs)) { + int rc = JAR_TOOL.run(out, System.err, jarArgs); + if (rc != 0) { fail("Could not list jar file."); } @@ -101,8 +104,8 @@ public class JarBackSlash { PipedInputStream pipedInput = new PipedInputStream(pipedOutput); PrintStream out = new PrintStream(pipedOutput); - Main jarTool = new Main(out, System.err, "jar"); - if (!jarTool.run(jarArgs)) { + int rc = JAR_TOOL.run(out, System.err, jarArgs); + if (rc != 0) { fail("Could not list jar file."); } diff --git a/jdk/test/tools/jar/JarEntryTime.java b/jdk/test/tools/jar/JarEntryTime.java index 1985bb1ab66..80fd65fba5c 100644 --- a/jdk/test/tools/jar/JarEntryTime.java +++ b/jdk/test/tools/jar/JarEntryTime.java @@ -24,7 +24,7 @@ /** * @test * @bug 4225317 6969651 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary Check extracted files have date as per those in the .jar file */ @@ -33,9 +33,14 @@ import java.io.PrintWriter; import java.nio.file.attribute.FileTime; import java.util.Date; import java.util.TimeZone; -import sun.tools.jar.Main; +import java.util.spi.ToolProvider; public class JarEntryTime { + static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + // ZipEntry's mod date has 2 seconds precision: give extra time to // allow for e.g. rounding/truncation and networked/samba drives. @@ -114,10 +119,8 @@ public class JarEntryTime { check(fileInner.setLastModified(earlier)); // Make a jar file from that directory structure - Main jartool = new Main(System.out, System.err, "jar"); - check(jartool.run(new String[] { - "cf", - jarFile.getName(), dirOuter.getName() } )); + check(JAR_TOOL.run(System.out, System.err, + "cf", jarFile.getName(), dirOuter.getName()) == 0); check(jarFile.exists()); check(cleanup(dirInner)); @@ -142,7 +145,6 @@ public class JarEntryTime { final long start = testFile.lastModified(); // Extract and check the last modified values are the current times. - // See sun.tools.jar.Main extractJar(jarFile, true); try (PrintWriter pw = new PrintWriter(testFile)) { diff --git a/jdk/test/tools/jar/UpdateJar.java b/jdk/test/tools/jar/UpdateJar.java index 524189bb841..c8e87bbc198 100644 --- a/jdk/test/tools/jar/UpdateJar.java +++ b/jdk/test/tools/jar/UpdateJar.java @@ -24,7 +24,7 @@ /** * @test * @bug 7175845 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary jar -uf should not change file permission */ @@ -32,9 +32,13 @@ import java.io.*; import java.nio.file.*; import java.nio.file.attribute.*; import java.util.Set; -import sun.tools.jar.Main; +import java.util.spi.ToolProvider; public class UpdateJar { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); private static void cleanup(String... fnames) throws Throwable { for (String fname : fnames) { @@ -55,12 +59,12 @@ public class UpdateJar { fos1.write(0); } String[] jarArgs = new String[] {"cfM0", jar, e0}; - if (!new Main(System.out, System.err, "jar").run(jarArgs)) { + if (JAR_TOOL.run(System.out, System.err, jarArgs) != 0) { fail("Could not create jar file."); } Set pm = Files.getPosixFilePermissions(Paths.get(jar)); jarArgs = new String[] {"uf", jar, e1}; - if (!new Main(System.out, System.err, "jar").run(jarArgs)) { + if (JAR_TOOL.run(System.out, System.err, jarArgs) != 0) { fail("Could not create jar file."); } equal(pm, Files.getPosixFilePermissions(Paths.get(jar))); diff --git a/jdk/test/tools/jar/UpdateManifest.java b/jdk/test/tools/jar/UpdateManifest.java index d07674cab17..31dbee5c68d 100644 --- a/jdk/test/tools/jar/UpdateManifest.java +++ b/jdk/test/tools/jar/UpdateManifest.java @@ -24,7 +24,7 @@ /** * @test * @bug 6434207 6442687 6984046 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary Ensure that jar ufm actually updates the * existing jar file's manifest with contents of the * manifest file. @@ -32,14 +32,19 @@ import java.io.*; import java.util.logging.*; +import java.util.spi.ToolProvider; import java.util.zip.*; -import sun.tools.jar.Main; public class UpdateManifest { static PrintStream out = System.out; static PrintStream err = System.err; static boolean debug = true; + static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + static final Logger JAR_LOGGER = Logger.getLogger("java.util.jar"); public static void realMain(String[] args) throws Throwable { @@ -64,17 +69,14 @@ public class UpdateManifest { // Create a jar file, specifying a Main-Class final String jarFileName = "um-existence.jar"; new File(jarFileName).delete(); // remove pre-existing first! - Main jartool = new Main(out, err, "jar"); - boolean status = jartool.run( - new String[] { "cfe", jarFileName, "Hello", existence.getPath() }); - check(status); + int status = JAR_TOOL.run(out, err, "cfe", jarFileName, + "Hello", existence.getPath()); + check(status == 0); checkManifest(jarFileName, "Hello"); // Update that jar file by changing the Main-Class - jartool = new Main(out, err, "jar"); - status = jartool.run( - new String[] { "ufe", jarFileName, "Bye" }); - check(status); + status = JAR_TOOL.run(out, err, "ufe", jarFileName, "Bye"); + check(status == 0); checkManifest(jarFileName, "Bye"); } @@ -101,11 +103,9 @@ public class UpdateManifest { // Create a jar file final String jarFileName = "um-test.jar"; new File(jarFileName).delete(); // remove pre-existing first! - Main jartool = new Main(out, err, "jar"); - boolean status = jartool.run( - new String[] {"cfm", jarFileName, - manifestOrig.getPath(), hello.getPath() }); - check(status); + int status = JAR_TOOL.run(out, err, "cfm", jarFileName, + manifestOrig.getPath(), hello.getPath()); + check(status == 0); // Create a new manifest, to use in updating the jar file. File manifestUpdate = File.createTempFile("manifestUpdate", ".txt"); @@ -122,10 +122,9 @@ public class UpdateManifest { pw.close(); // Update jar file with manifest - jartool = new Main(out, err, "jar"); - status = jartool.run( - new String[] { "ufm", jarFileName, manifestUpdate.getPath() }); - check(status); + status = JAR_TOOL.run(out, err, "ufm", + jarFileName, manifestUpdate.getPath()); + check(status == 0); // Extract jar, and verify contents of manifest file File f = new File(jarFileName); diff --git a/jdk/test/tools/jar/index/MetaInf.java b/jdk/test/tools/jar/index/MetaInf.java index 29108c72d2f..1353acf87f3 100644 --- a/jdk/test/tools/jar/index/MetaInf.java +++ b/jdk/test/tools/jar/index/MetaInf.java @@ -24,17 +24,21 @@ /* * @test * @bug 4408526 6854795 - * @modules jdk.jartool/sun.tools.jar + * @modules jdk.jartool * @summary Index the non-meta files in META-INF, such as META-INF/services. */ import java.io.*; import java.util.Arrays; import java.util.jar.*; -import sun.tools.jar.Main; +import java.util.spi.ToolProvider; import java.util.zip.ZipFile; public class MetaInf { + static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); static String jarName = "a.jar"; static String INDEX = "META-INF/INDEX.LIST"; @@ -43,7 +47,7 @@ public class MetaInf { System.getProperty("test.src") + File.separatorChar + "jarcontents"; static void run(String ... args) { - if (! new Main(System.out, System.err, "jar").run(args)) + if (JAR_TOOL.run(System.out, System.err, args) != 0) throw new Error("jar failed: args=" + Arrays.toString(args)); } diff --git a/jdk/test/tools/jlink/JLinkTest.java b/jdk/test/tools/jlink/JLinkTest.java index d6e9d1bca92..2215bef8ec0 100644 --- a/jdk/test/tools/jlink/JLinkTest.java +++ b/jdk/test/tools/jlink/JLinkTest.java @@ -32,13 +32,13 @@ import java.nio.file.Paths; import java.util.ArrayList; import java.util.Collections; import java.util.List; +import java.util.spi.ToolProvider; import java.util.stream.Stream; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.internal.PluginRepository; import tests.Helper; import tests.JImageGenerator; -import tests.JImageGenerator.InMemoryFile; /* * @test @@ -48,13 +48,17 @@ import tests.JImageGenerator.InMemoryFile; * @modules java.base/jdk.internal.jimage * jdk.jdeps/com.sun.tools.classfile * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jmod * jdk.jlink/jdk.tools.jimage * jdk.compiler * @build tests.* * @run main/othervm -Xmx1g JLinkTest */ public class JLinkTest { + static final ToolProvider JLINK_TOOL = ToolProvider.findFirst("jlink") + .orElseThrow(() -> + new RuntimeException("jlink tool not found") + ); + // number of built-in plugins from jdk.jlink module private static int getNumJlinkPlugins() { ModuleDescriptor desc = Plugin.class.getModule().getDescriptor(); @@ -180,7 +184,8 @@ public class JLinkTest { { // Help StringWriter writer = new StringWriter(); - jdk.tools.jlink.internal.Main.run(new String[]{"--help"}, new PrintWriter(writer)); + PrintWriter pw = new PrintWriter(writer); + JLINK_TOOL.run(pw, pw, "--help"); String output = writer.toString(); if (output.split("\n").length < 10) { System.err.println(output); @@ -202,7 +207,9 @@ public class JLinkTest { { // List plugins StringWriter writer = new StringWriter(); - jdk.tools.jlink.internal.Main.run(new String[]{"--list-plugins"}, new PrintWriter(writer)); + PrintWriter pw = new PrintWriter(writer); + + JLINK_TOOL.run(pw, pw, "--list-plugins"); String output = writer.toString(); long number = Stream.of(output.split("\\R")) .filter((s) -> s.matches("Plugin Name:.*")) diff --git a/jdk/test/tools/jlink/basic/BasicTest.java b/jdk/test/tools/jlink/basic/BasicTest.java index 780cbca9cbc..6ddc4a190f9 100644 --- a/jdk/test/tools/jlink/basic/BasicTest.java +++ b/jdk/test/tools/jlink/basic/BasicTest.java @@ -27,8 +27,7 @@ * @author Andrei Eremeev * @library /lib/testlibrary * @modules java.base/jdk.internal.module - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jmod + * jdk.jlink * jdk.compiler * @build jdk.testlibrary.ProcessTools * jdk.testlibrary.OutputAnalyzer @@ -44,11 +43,21 @@ import java.nio.file.Paths; import java.util.ArrayList; import java.util.Collections; import java.util.List; +import java.util.spi.ToolProvider; import jdk.testlibrary.OutputAnalyzer; import jdk.testlibrary.ProcessTools; public class BasicTest { + static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); + + static final ToolProvider JLINK_TOOL = ToolProvider.findFirst("jlink") + .orElseThrow(() -> + new RuntimeException("jlink tool not found") + ); private final Path jdkHome = Paths.get(System.getProperty("test.jdk")); private final Path jdkMods = jdkHome.resolve("jmods"); @@ -110,20 +119,22 @@ public class BasicTest { "--add-modules", modName, "--output", image.toString()); Collections.addAll(args, options); - int rc = jdk.tools.jlink.internal.Main.run(args.toArray(new String[args.size()]), new PrintWriter(System.out)); + + PrintWriter pw = new PrintWriter(System.out); + int rc = JLINK_TOOL.run(pw, pw, args.toArray(new String[args.size()])); if (rc != 0) { throw new AssertionError("Jlink failed: rc = " + rc); } } private void runJmod(String cp, String modName) { - int rc = jdk.tools.jmod.Main.run(new String[] { + int rc = JMOD_TOOL.run(System.out, System.out, new String[] { "create", "--class-path", cp, "--module-version", "1.0", "--main-class", "jdk.test.Test", jmods.resolve(modName + ".jmod").toString(), - }, System.out); + }); if (rc != 0) { throw new AssertionError("Jmod failed: rc = " + rc); } diff --git a/jdk/test/tools/jmod/JmodNegativeTest.java b/jdk/test/tools/jmod/JmodNegativeTest.java index 317587f5fb5..02a3791dfac 100644 --- a/jdk/test/tools/jmod/JmodNegativeTest.java +++ b/jdk/test/tools/jmod/JmodNegativeTest.java @@ -24,8 +24,8 @@ /* * @test * @library /lib/testlibrary - * @modules jdk.jlink/jdk.tools.jmod - * jdk.compiler + * @modules jdk.compiler + * jdk.jlink * @build jdk.testlibrary.FileUtils CompilerUtils * @run testng JmodNegativeTest * @summary Negative tests for jmod @@ -39,6 +39,7 @@ import java.util.Arrays; import java.util.List; import java.util.function.Consumer; import java.util.function.Supplier; +import java.util.spi.ToolProvider; import java.util.zip.ZipOutputStream; import jdk.testlibrary.FileUtils; import org.testng.annotations.BeforeTest; @@ -51,6 +52,11 @@ import static org.testng.Assert.assertTrue; public class JmodNegativeTest { + static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); + static final String TEST_SRC = System.getProperty("test.src", "."); static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); static final Path EXPLODED_DIR = Paths.get("build"); @@ -515,7 +521,7 @@ public class JmodNegativeTest { ByteArrayOutputStream baos = new ByteArrayOutputStream(); PrintStream ps = new PrintStream(baos); System.out.println("jmod " + Arrays.asList(args)); - int ec = jdk.tools.jmod.Main.run(args, ps); + int ec = JMOD_TOOL.run(ps, ps, args); return new JmodResult(ec, new String(baos.toByteArray(), UTF_8)); } diff --git a/jdk/test/tools/jmod/JmodTest.java b/jdk/test/tools/jmod/JmodTest.java index 064ba585297..5be6a692daf 100644 --- a/jdk/test/tools/jmod/JmodTest.java +++ b/jdk/test/tools/jmod/JmodTest.java @@ -24,8 +24,8 @@ /* * @test * @library /lib/testlibrary - * @modules jdk.jlink/jdk.tools.jmod - * jdk.compiler + * @modules jdk.compiler + * jdk.jlink * @build jdk.testlibrary.FileUtils CompilerUtils * @run testng JmodTest * @summary Basic test for jmod @@ -38,6 +38,7 @@ import java.nio.file.*; import java.util.*; import java.util.function.Consumer; import java.util.regex.Pattern; +import java.util.spi.ToolProvider; import java.util.stream.Stream; import jdk.testlibrary.FileUtils; import org.testng.annotations.BeforeTest; @@ -51,6 +52,11 @@ import static org.testng.Assert.*; public class JmodTest { + static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); + static final String TEST_SRC = System.getProperty("test.src", "."); static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); static final Path EXPLODED_DIR = Paths.get("build"); @@ -479,7 +485,7 @@ public class JmodTest { ByteArrayOutputStream baos = new ByteArrayOutputStream(); PrintStream ps = new PrintStream(baos); System.out.println("jmod " + Arrays.asList(args)); - int ec = jdk.tools.jmod.Main.run(args, ps); + int ec = JMOD_TOOL.run(ps, ps, args); return new JmodResult(ec, new String(baos.toByteArray(), UTF_8)); } diff --git a/jdk/test/tools/jmod/hashes/HashesTest.java b/jdk/test/tools/jmod/hashes/HashesTest.java index 616d393b97a..e01ecdb8046 100644 --- a/jdk/test/tools/jmod/hashes/HashesTest.java +++ b/jdk/test/tools/jmod/hashes/HashesTest.java @@ -27,8 +27,7 @@ * @author Andrei Eremeev * @library /lib/testlibrary * @modules java.base/jdk.internal.module - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jmod + * jdk.jlink * jdk.compiler * @build CompilerUtils * @run testng HashesTest @@ -53,6 +52,7 @@ import java.util.Collections; import java.util.List; import java.util.Optional; import java.util.Set; +import java.util.spi.ToolProvider; import java.util.stream.Collectors; import jdk.internal.module.ConfigurableModuleFinder; @@ -63,6 +63,10 @@ import org.testng.annotations.Test; import static org.testng.Assert.*; public class HashesTest { + static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); private final Path testSrc = Paths.get(System.getProperty("test.src")); private final Path modSrc = testSrc.resolve("src"); @@ -204,7 +208,7 @@ public class HashesTest { } private void runJmod(List args) { - int rc = jdk.tools.jmod.Main.run(args.toArray(new String[args.size()]), System.out); + int rc = JMOD_TOOL.run(System.out, System.out, args.toArray(new String[args.size()])); System.out.println("jmod options: " + args.stream().collect(Collectors.joining(" "))); if (rc != 0) { throw new AssertionError("Jmod failed: rc = " + rc); diff --git a/jdk/test/tools/launcher/modules/basic/BasicTest.java b/jdk/test/tools/launcher/modules/basic/BasicTest.java index 233fa29e00b..3256f354c78 100644 --- a/jdk/test/tools/launcher/modules/basic/BasicTest.java +++ b/jdk/test/tools/launcher/modules/basic/BasicTest.java @@ -24,9 +24,9 @@ /** * @test * @library /lib/testlibrary - * @modules jdk.jartool/sun.tools.jar - * jdk.jlink/jdk.tools.jmod - * jdk.compiler + * @modules jdk.compiler + * jdk.jartool + * jdk.jlink * @build BasicTest CompilerUtils jdk.testlibrary.* * @run testng BasicTest * @summary Basic test of starting an application as a module @@ -36,6 +36,7 @@ import java.io.File; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.spi.ToolProvider; import jdk.testlibrary.ProcessTools; @@ -46,6 +47,14 @@ import static org.testng.Assert.*; @Test public class BasicTest { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + private static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod") + .orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); private static final Path USER_DIR = Paths.get(System.getProperty("user.dir")); @@ -132,10 +141,8 @@ public class BasicTest { "--main-class=" + MAIN_CLASS, "-C", classes, "." }; - boolean success - = new sun.tools.jar.Main(System.out, System.out, "jar") - .run(args); - assertTrue(success); + int rc = JAR_TOOL.run(System.out, System.out, args); + assertTrue(rc == 0); // java --module-path mlib -module $TESTMODULE int exitValue = exec("--module-path", dir.toString(), @@ -164,8 +171,8 @@ public class BasicTest { "--main-class", MAIN_CLASS, jmod }; - jdk.tools.jmod.JmodTask task = new jdk.tools.jmod.JmodTask(); - assertEquals(task.run(args), 0); + + assertEquals(JMOD_TOOL.run(System.out, System.out, args), 0); // java --module-path mods --module $TESTMODULE int exitValue = exec("--module-path", dir.toString(), @@ -229,10 +236,8 @@ public class BasicTest { "--file=" + jar, "-C", classes, "." }; - boolean success - = new sun.tools.jar.Main(System.out, System.out, "jar") - .run(args); - assertTrue(success); + int rc = JAR_TOOL.run(System.out, System.out, args); + assertTrue(rc == 0); // java --module-path mods -m $TESTMODULE int exitValue = exec("--module-path", dir.toString(), "-m", TEST_MODULE); diff --git a/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java index acf65bc1475..fe9a293be57 100644 --- a/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java +++ b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java @@ -26,7 +26,7 @@ * @bug 8159596 * @library /lib/testlibrary * @modules jdk.compiler - * jdk.jartool/sun.tools.jar + * jdk.jartool * @build DryRunTest CompilerUtils jdk.testlibrary.ProcessTools * @run testng DryRunTest * @summary Test java --dry-run @@ -37,6 +37,7 @@ import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.spi.ToolProvider; import jdk.testlibrary.ProcessTools; @@ -78,8 +79,8 @@ public class DryRunTest { Files.createDirectories(LIBS_DIR); // create JAR files with no module-info.class - assertTrue(jar(M_MODULE, "p/Lib.class")); - assertTrue(jar(TEST_MODULE, "jdk/test/Main.class")); + assertTrue(jar(M_MODULE, "p/Lib.class") == 0); + assertTrue(jar(TEST_MODULE, "jdk/test/Main.class") == 0); } /** @@ -197,7 +198,12 @@ public class DryRunTest { assertTrue(exitValue != 0); } - private static boolean jar(String name, String entries) throws IOException { + private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar") + .orElseThrow(() -> + new RuntimeException("jar tool not found") + ); + + private static int jar(String name, String entries) throws IOException { Path jar = LIBS_DIR.resolve(name + ".jar"); // jar --create ... @@ -207,8 +213,6 @@ public class DryRunTest { "--file=" + jar, "-C", classes, entries }; - boolean success - = new sun.tools.jar.Main(System.out, System.out, "jar").run(args); - return success; + return JAR_TOOL.run(System.out, System.out, args); } } diff --git a/jdk/test/tools/lib/tests/JImageGenerator.java b/jdk/test/tools/lib/tests/JImageGenerator.java index beaf2dbe0b6..59e7d37cbce 100644 --- a/jdk/test/tools/lib/tests/JImageGenerator.java +++ b/jdk/test/tools/lib/tests/JImageGenerator.java @@ -338,6 +338,10 @@ public class JImageGenerator { } public static class JModTask { + static final java.util.spi.ToolProvider JMOD_TOOL = + java.util.spi.ToolProvider.findFirst("jmod").orElseThrow(() -> + new RuntimeException("jmod tool not found") + ); private final List classpath = new ArrayList<>(); private final List libs = new ArrayList<>(); @@ -477,7 +481,8 @@ public class JImageGenerator { String[] args = optionsJMod(cmd); System.err.println("jmod options: " + optionsPrettyPrint(args)); ByteArrayOutputStream baos = new ByteArrayOutputStream(); - int exitCode = jdk.tools.jmod.Main.run(args, new PrintStream(baos)); + PrintStream ps = new PrintStream(baos); + int exitCode = JMOD_TOOL.run(ps, ps, args); String msg = new String(baos.toByteArray()); return new Result(exitCode, msg, output); } @@ -556,6 +561,10 @@ public class JImageGenerator { } public static class JLinkTask { + static final java.util.spi.ToolProvider JLINK_TOOL = + java.util.spi.ToolProvider.findFirst("jlink").orElseThrow(() -> + new RuntimeException("jlink tool not found") + ); private final List jars = new ArrayList<>(); private final List jmods = new ArrayList<>(); @@ -691,7 +700,8 @@ public class JImageGenerator { String[] args = optionsJLink(); System.err.println("jlink options: " + optionsPrettyPrint(args)); StringWriter writer = new StringWriter(); - int exitCode = jdk.tools.jlink.internal.Main.run(args, new PrintWriter(writer)); + PrintWriter pw = new PrintWriter(writer); + int exitCode = JLINK_TOOL.run(pw, pw, args); return new Result(exitCode, writer.toString(), output); } @@ -699,7 +709,8 @@ public class JImageGenerator { String[] args = optionsPostProcessJLink(); System.err.println("jlink options: " + optionsPrettyPrint(args)); StringWriter writer = new StringWriter(); - int exitCode = jdk.tools.jlink.internal.Main.run(args, new PrintWriter(writer)); + PrintWriter pw = new PrintWriter(writer); + int exitCode = JLINK_TOOL.run(pw, pw, args); return new Result(exitCode, writer.toString(), output); } } From b0a2502f7b16f28611e5d226230b2187e604e5bd Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Wed, 12 Oct 2016 17:36:19 -0700 Subject: [PATCH 26/43] 8058152: JDK accepts XSLT stylesheet having import element erroneously placed Reviewed-by: naoto, lancea --- .../xalan/internal/xsltc/compiler/Parser.java | 6 + .../xsltc/compiler/SyntaxTreeNode.java | 18 +++ .../xsltc/compiler/util/ErrorMessages.java | 8 + .../xsltc/compiler/util/ErrorMsg.java | 1 + .../unittest/transform/StylesheetTest.java | 149 ++++++++++++++++++ .../xml/jaxp/unittest/transform/XSLImport.xsl | 21 +++ .../unittest/transform/XSLInclude_footer.xsl | 9 ++ .../unittest/transform/XSLInclude_header.xsl | 8 + .../unittest/transform/XSLInclude_main.xsl | 20 +++ 9 files changed, 240 insertions(+) create mode 100644 jaxp/test/javax/xml/jaxp/unittest/transform/StylesheetTest.java create mode 100644 jaxp/test/javax/xml/jaxp/unittest/transform/XSLImport.xsl create mode 100644 jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_footer.xsl create mode 100644 jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_header.xsl create mode 100644 jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_main.xsl diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java index 2c223d644c7..d8d16ecb516 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java @@ -1342,6 +1342,12 @@ public class Parser implements Constants, ContentHandler { } else { SyntaxTreeNode parent = _parentStack.peek(); + if (element.getClass().isAssignableFrom(Import.class) && + parent.notTypeOf(Import.class)) { + ErrorMsg err = new ErrorMsg(ErrorMsg.IMPORT_PRECEDE_OTHERS_ERR, + prefix+':'+localname); + throw new SAXException(err.toString()); + } parent.addElement(element); element.setParent(parent); } diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/SyntaxTreeNode.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/SyntaxTreeNode.java index d6fabc7bfc5..505bea6d1ce 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/SyntaxTreeNode.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/SyntaxTreeNode.java @@ -523,6 +523,24 @@ public abstract class SyntaxTreeNode implements Constants { } } + /** + * Checks whether any children of this node is not of the specified type. + * + * @param type the type to be checked against + * @return true if there is at least one child that is not of the specified + * type, false otherwise. + */ + public boolean notTypeOf(Class type) { + if (_contents.size() > 0) { + for (SyntaxTreeNode item : _contents) { + if (!item.getClass().isAssignableFrom(type)) { + return true; + } + } + } + return false; + } + /** * Return true if the node represents a simple RTF. * diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMessages.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMessages.java index 4f0ce4794e8..581d3cc2cb7 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMessages.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMessages.java @@ -273,6 +273,14 @@ public class ErrorMessages extends ListResourceBundle { {ErrorMsg.CIRCULAR_INCLUDE_ERR, "Circular import/include. Stylesheet ''{0}'' already loaded."}, + /* + * Note to translators: "xsl:import" and "xsl:include" are keywords that + * should not be translated. + */ + {ErrorMsg.IMPORT_PRECEDE_OTHERS_ERR, + "The xsl:import element children must precede all other element children of " + + "an xsl:stylesheet element, including any xsl:include element children."}, + /* * Note to translators: A result-tree fragment is a portion of a * resulting XML document represented as a tree. "" is a diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMsg.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMsg.java index 69d410b2fa5..50803c03a87 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMsg.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/util/ErrorMsg.java @@ -70,6 +70,7 @@ public final class ErrorMsg { public static final String STRAY_ATTRIBUTE_ERR = "STRAY_ATTRIBUTE_ERR"; public static final String ILLEGAL_ATTRIBUTE_ERR = "ILLEGAL_ATTRIBUTE_ERR"; public static final String CIRCULAR_INCLUDE_ERR = "CIRCULAR_INCLUDE_ERR"; + public static final String IMPORT_PRECEDE_OTHERS_ERR = "IMPORT_PRECEDE_OTHERS_ERR"; public static final String RESULT_TREE_SORT_ERR = "RESULT_TREE_SORT_ERR"; public static final String SYMBOLS_REDEF_ERR = "SYMBOLS_REDEF_ERR"; public static final String XSL_VERSION_ERR = "XSL_VERSION_ERR"; diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/StylesheetTest.java b/jaxp/test/javax/xml/jaxp/unittest/transform/StylesheetTest.java new file mode 100644 index 00000000000..cf6aa98f30f --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/StylesheetTest.java @@ -0,0 +1,149 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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. + * + * 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 transform; + +import java.io.StringReader; +import org.xml.sax.InputSource; + +import javax.xml.transform.Transformer; +import javax.xml.transform.TransformerFactory; +import javax.xml.transform.sax.SAXSource; +import javax.xml.transform.TransformerConfigurationException; +import org.testng.annotations.Listeners; +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; + +/** + * @test + * @bug 8058152 + * @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest + * @run testng/othervm -DrunSecMngr=true transform.StylesheetTest + * @run testng/othervm transform.StylesheetTest + * @summary this test contains test cases for verifying stylesheet + */ +@Listeners(jaxp.library.FilePolicy.class) +public class StylesheetTest { + + /** + * @bug 8058152 + * Verifies that an error is reported if the xsl:import element + * is not at the top of the stylesheet. + * @throws TransformerConfigurationException + */ + @Test(dataProvider = "invalidImport", expectedExceptions = TransformerConfigurationException.class) + public void testInvalidImport(String xsl) throws TransformerConfigurationException { + StringReader xsl1 = new StringReader(xsl); + TransformerFactory factory = TransformerFactory.newInstance(); + SAXSource xslSource = new SAXSource(new InputSource(xsl1)); + Transformer transformer = factory.newTransformer(xslSource); + } + + /** + * @bug 8058152 + * Verifies that valid xsl:import elements are accepted + * @throws TransformerConfigurationException + */ + @Test(dataProvider = "validImport") + public void testValidImport(String file) throws TransformerConfigurationException { + String xsl = getClass().getResource(file).getFile(); + TransformerFactory factory = TransformerFactory.newInstance(); + SAXSource xslSource = new SAXSource(new InputSource(xsl)); + Transformer transformer = factory.newTransformer(xslSource); + } + + /* + DataProvider: for testing with xsl:import placed incorrectly + Data: stylesheet + */ + @DataProvider(name = "invalidImport") + public Object[][] getInvalid() { + + return new Object[][]{ + // xsl:import after template and include elements + {"\n" + + "\n" + + "\n" + + " \n" + + " \n" + + " \n" + + " \n" + + " \n" + + " \n" + + " \n" + + "\n" + + " \n" + + "

    \n" + + " \n" + + "

    \n" + + " \n" + + " \n" + + " \n" + + "\n" + + ""}, + + // xsl:import inside template + {"\n" + + "\n" + + "\n" + + " \n" + + " " + + " \n" + + " \n" + + " \n" + + " \n" + + "\n" + + ""}, + + // xsl:import after xsl:include + {"\n" + + "\n" + + " \n" + + " \n" + + "\n" + + " \n" + + "

    \n" + + " \n" + + "

    \n" + + "
    \n" + + "\n" + + "
    "} + }; + } + + /* + DataProvider: for testing with xsl:import placed correctly + Data: path to stylesheet + */ + @DataProvider(name = "validImport") + public Object[][] getValid() { + + return new Object[][]{ + // xsl:import at the top + {"XSLInclude_main.xsl"}, + + // two xsl:import elements at the top + {"XSLImport.xsl"} + }; + } +} diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/XSLImport.xsl b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLImport.xsl new file mode 100644 index 00000000000..5004c613371 --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLImport.xsl @@ -0,0 +1,21 @@ + + + + + + + + + + + + + +

    + +

    +
    + + + +
    \ No newline at end of file diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_footer.xsl b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_footer.xsl new file mode 100644 index 00000000000..8859250947b --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_footer.xsl @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_header.xsl b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_header.xsl new file mode 100644 index 00000000000..57dbefef017 --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_header.xsl @@ -0,0 +1,8 @@ + + + + +

    +
    + +
    \ No newline at end of file diff --git a/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_main.xsl b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_main.xsl new file mode 100644 index 00000000000..ab5c4d0907a --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/transform/XSLInclude_main.xsl @@ -0,0 +1,20 @@ + + + + + + + + + + + + +

    + +

    +
    + + + +
    \ No newline at end of file From 6e9244aea43d2af419368b599eec17e7a3cc3003 Mon Sep 17 00:00:00 2001 From: Tim Du Date: Thu, 13 Oct 2016 00:45:38 -0700 Subject: [PATCH 27/43] 8164322: Test sun/security/pkcs11/PKCS11Test.java shall be updated to run on ARM platforms Reviewed-by: xuelei --- jdk/test/sun/security/pkcs11/PKCS11Test.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/jdk/test/sun/security/pkcs11/PKCS11Test.java b/jdk/test/sun/security/pkcs11/PKCS11Test.java index 3752baba8da..59c284d5efa 100644 --- a/jdk/test/sun/security/pkcs11/PKCS11Test.java +++ b/jdk/test/sun/security/pkcs11/PKCS11Test.java @@ -299,11 +299,12 @@ public abstract class PKCS11Test { + props.getProperty("os.arch") + "-" + props.getProperty("sun.arch.data.model"); String[] nssLibDirs = osMap.get(osid); if (nssLibDirs == null) { - System.out.println("Unsupported OS, skipping: " + osid); + System.out.println("Warning: unsupported OS: " + osid + + ", please initialize NSS librarys location firstly, skipping test"); return null; } if (nssLibDirs.length == 0) { - System.out.println("NSS not supported on this platform, skipping test"); + System.out.println("Warning: NSS not supported on this platform, skipping test"); return null; } String nssLibDir = null; @@ -315,6 +316,10 @@ public abstract class PKCS11Test { break; } } + if (nssLibDir == null) { + System.out.println("Warning: can't find NSS librarys on this machine, skipping test"); + return null; + } return nssLibDir; } @@ -624,6 +629,11 @@ public abstract class PKCS11Test { PKCS11_BASE + "/nss/lib/windows-amd64/".replace('/', SEP)}); osMap.put("MacOSX-x86_64-64", new String[]{ PKCS11_BASE + "/nss/lib/macosx-x86_64/"}); + osMap.put("Linux-arm-32", new String[]{ + "/usr/lib/arm-linux-gnueabi/nss/", + "/usr/lib/arm-linux-gnueabihf/nss/"}); + osMap.put("Linux-aarch64-64", new String[]{ + "/usr/lib/aarch64-linux-gnu/nss/"}); } private final static char[] hexDigits = "0123456789abcdef".toCharArray(); From 410b8c8f8ff4fe76d823b488c6fa94dbf9fec094 Mon Sep 17 00:00:00 2001 From: Srinivas Dama Date: Thu, 13 Oct 2016 01:59:39 -0700 Subject: [PATCH 28/43] 8055033: Shell tests for jrunscript don't pass through VM options Passed jtreg env variables TESTVMOPTS, TESTJAVAOPTS to java and TESTTOOLVMOPTS, TESTJAVACOPTS to javac launchers Reviewed-by: sundar --- jdk/test/sun/tools/jrunscript/jrunscript-DTest.sh | 2 +- jdk/test/sun/tools/jrunscript/jrunscript-argsTest.sh | 2 +- jdk/test/sun/tools/jrunscript/jrunscript-cpTest.sh | 4 ++-- jdk/test/sun/tools/jrunscript/jrunscript-eTest.sh | 2 +- jdk/test/sun/tools/jrunscript/jrunscript-fTest.sh | 2 +- jdk/test/sun/tools/jrunscript/jrunscriptTest.sh | 2 +- 6 files changed, 7 insertions(+), 7 deletions(-) diff --git a/jdk/test/sun/tools/jrunscript/jrunscript-DTest.sh b/jdk/test/sun/tools/jrunscript/jrunscript-DTest.sh index b2102ef6a62..4e99fcd8adb 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscript-DTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscript-DTest.sh @@ -33,7 +33,7 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 diff --git a/jdk/test/sun/tools/jrunscript/jrunscript-argsTest.sh b/jdk/test/sun/tools/jrunscript/jrunscript-argsTest.sh index b104e965ddf..ae36204249b 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscript-argsTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscript-argsTest.sh @@ -33,7 +33,7 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 diff --git a/jdk/test/sun/tools/jrunscript/jrunscript-cpTest.sh b/jdk/test/sun/tools/jrunscript/jrunscript-cpTest.sh index 4b989ef2de1..67a8176fe9d 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscript-cpTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscript-cpTest.sh @@ -33,14 +33,14 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 fi rm -f Hello.class -${JAVAC} ${TESTSRC}/Hello.java -d . +${JAVAC} ${TESTTOOLVMOPTS} ${TESTJAVACOPTS} ${TESTSRC}/Hello.java -d . # we check whether classpath setting for app classes # work with jrunscript. Script should be able to diff --git a/jdk/test/sun/tools/jrunscript/jrunscript-eTest.sh b/jdk/test/sun/tools/jrunscript/jrunscript-eTest.sh index 97c62a261f9..7b3510c4af3 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscript-eTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscript-eTest.sh @@ -33,7 +33,7 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 diff --git a/jdk/test/sun/tools/jrunscript/jrunscript-fTest.sh b/jdk/test/sun/tools/jrunscript/jrunscript-fTest.sh index 8c402a316ea..6be1e9132c6 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscript-fTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscript-fTest.sh @@ -33,7 +33,7 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 diff --git a/jdk/test/sun/tools/jrunscript/jrunscriptTest.sh b/jdk/test/sun/tools/jrunscript/jrunscriptTest.sh index ab4cb16dc13..b95273c937b 100644 --- a/jdk/test/sun/tools/jrunscript/jrunscriptTest.sh +++ b/jdk/test/sun/tools/jrunscript/jrunscriptTest.sh @@ -33,7 +33,7 @@ . ${TESTSRC-.}/common.sh setup -${JAVA} -cp ${TESTCLASSES} CheckEngine +${JAVA} ${TESTVMOPTS} ${TESTJAVAOPTS} -cp ${TESTCLASSES} CheckEngine if [ $? -eq 2 ]; then echo "No js engine found and engine not required; test vacuously passes." exit 0 From 02ca9985fc8b3d25e37a7aea41378f0e8a93cd6b Mon Sep 17 00:00:00 2001 From: Vinnie Ryan Date: Thu, 13 Oct 2016 12:37:42 +0100 Subject: [PATCH 29/43] 8167371: KeyStoreSpi.engineSetEntry should throw an Exception if password protection alg is specified Reviewed-by: xuelei, mullan --- .../classes/java/security/KeyStoreSpi.java | 8 ++++ .../security/KeyStore/TestKeyStoreBasic.java | 44 ++++++++++++++++++- 2 files changed, 50 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/security/KeyStoreSpi.java b/jdk/src/java.base/share/classes/java/security/KeyStoreSpi.java index 65ede7a2a83..096a7b48dc1 100644 --- a/jdk/src/java.base/share/classes/java/security/KeyStoreSpi.java +++ b/jdk/src/java.base/share/classes/java/security/KeyStoreSpi.java @@ -479,6 +479,10 @@ public abstract class KeyStoreSpi { } else if (engineIsKeyEntry(alias)) { KeyStore.PasswordProtection pp = (KeyStore.PasswordProtection)protParam; + if (pp.getProtectionAlgorithm() != null) { + throw new KeyStoreException( + "unsupported password protection algorithm"); + } char[] password = pp.getPassword(); Key key = engineGetKey(alias, password); @@ -524,6 +528,10 @@ public abstract class KeyStoreSpi { KeyStore.PasswordProtection pProtect = null; if (protParam != null) { pProtect = (KeyStore.PasswordProtection)protParam; + if (pProtect.getProtectionAlgorithm() != null) { + throw new KeyStoreException( + "unsupported password protection algorithm"); + } } // set entry diff --git a/jdk/test/java/security/KeyStore/TestKeyStoreBasic.java b/jdk/test/java/security/KeyStore/TestKeyStoreBasic.java index fe18a8943a5..b96c26499c3 100644 --- a/jdk/test/java/security/KeyStore/TestKeyStoreBasic.java +++ b/jdk/test/java/security/KeyStore/TestKeyStoreBasic.java @@ -40,7 +40,7 @@ import java.util.Base64; /* * @test - * @bug 8048621 8133090 + * @bug 8048621 8133090 8167371 * @summary Test basic operations with keystores (jks, jceks, pkcs12) * @author Yu-Ching Valerie PENG */ @@ -116,6 +116,8 @@ public class TestKeyStoreBasic { }; private static final String ALIAS_HEAD = "test"; + private static final String CRYPTO_ALG = "PBEWithHmacSHA256AndAES_128"; + public static void main(String args[]) throws Exception { TestKeyStoreBasic jstest = new TestKeyStoreBasic(); jstest.run(); @@ -125,7 +127,7 @@ public class TestKeyStoreBasic { for (String provider : PROVIDERS) { try { runTest(provider); - System.out.println("Test with provider " + provider + "passed"); + System.out.println("Test with provider " + provider + " passed"); } catch (java.security.KeyStoreException e) { if (provider.equals("SunPKCS11-Solaris")) { System.out.println("KeyStoreException is expected: " @@ -236,6 +238,44 @@ public class TestKeyStoreBasic { // compare the creation date of the 2 key stores for all aliases compareCreationDate(ks, ks2, numEntries); + // check setEntry/getEntry with a password protection algorithm + if ("PKCS12".equalsIgnoreCase(ks.getType())) { + System.out.println( + "Skipping the setEntry/getEntry check for PKCS12 keystore..."); + return; + } + String alias = ALIAS_HEAD + ALIAS_HEAD; + KeyStore.PasswordProtection pw = + new KeyStore.PasswordProtection(PASSWD2, CRYPTO_ALG, null); + KeyStore.PrivateKeyEntry entry = + new KeyStore.PrivateKeyEntry(privateKey, new Certificate[]{ cert }); + checkSetEntry(ks, alias, pw, entry); + ks.setEntry(alias, entry, new KeyStore.PasswordProtection(PASSWD2)); + checkGetEntry(ks, alias, pw); + } + + // check setEntry with a password protection algorithm + private void checkSetEntry(KeyStore ks, String alias, + KeyStore.PasswordProtection pw, KeyStore.Entry entry) throws Exception { + try { + ks.setEntry(alias, entry, pw); + throw new Exception( + "ERROR: expected KeyStore.setEntry to throw an exception"); + } catch (KeyStoreException e) { + // ignore the expected exception + } + } + + // check getEntry with a password protection algorithm + private void checkGetEntry(KeyStore ks, String alias, + KeyStore.PasswordProtection pw) throws Exception { + try { + ks.getEntry(alias, pw); + throw new Exception( + "ERROR: expected KeyStore.getEntry to throw an exception"); + } catch (KeyStoreException e) { + // ignore the expected exception + } } // check key store type From 7bcdb604388de4dd570109ac52080c8198f3d948 Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Thu, 13 Oct 2016 08:00:10 -0700 Subject: [PATCH 30/43] 8167511: IgnoreModulePropertiesTest.java needs update for JDK-8162401 Reviewed-by: lfoltan, hseigel --- .../test/runtime/modules/IgnoreModulePropertiesTest.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/hotspot/test/runtime/modules/IgnoreModulePropertiesTest.java b/hotspot/test/runtime/modules/IgnoreModulePropertiesTest.java index 3714a9ee97a..31b0fb5b7e3 100644 --- a/hotspot/test/runtime/modules/IgnoreModulePropertiesTest.java +++ b/hotspot/test/runtime/modules/IgnoreModulePropertiesTest.java @@ -67,10 +67,11 @@ public class IgnoreModulePropertiesTest { } public static void main(String[] args) throws Exception { - testOption("--add-modules", "java.sqlx", "jdk.module.addmods", "java.lang.module.ResolutionException"); + testOption("--add-modules", "java.sqlx", "jdk.module.addmods.0", "java.lang.module.ResolutionException"); testOption("--limit-modules", "java.sqlx", "jdk.module.limitmods", "java.lang.module.ResolutionException"); - testOption("--add-reads", "xyzz=yyzd", "jdk.module.addreads.0", "java.lang.RuntimeException"); - testOption("--add-exports", "java.base/xyzz=yyzd", "jdk.module.addexports.0", "java.lang.RuntimeException"); + testOption("--add-reads", "xyzz=yyzd", "jdk.module.addreads.0", "WARNING: Unknown module: xyzz"); + testOption("--add-exports", "java.base/xyzz=yyzd", "jdk.module.addexports.0", + "WARNING: package xyzz not in java.base"); testOption("--patch-module", "=d", "jdk.module.patch.0", "IllegalArgumentException"); } } From dd8ac98cde2a6961c3e38ab21ee753229c2d7e44 Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Thu, 13 Oct 2016 09:35:07 -0700 Subject: [PATCH 31/43] 8166258: Unexpected code conversion by HKSCS converters Reviewed-by: naoto --- .../share/classes/sun/nio/cs/HKSCS.java | 2 + jdk/test/sun/nio/cs/TestHKSCS.java | 49 +++++++++++++++++++ 2 files changed, 51 insertions(+) create mode 100644 jdk/test/sun/nio/cs/TestHKSCS.java diff --git a/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java b/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java index ed920e74ade..1b166447b78 100644 --- a/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java +++ b/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java @@ -432,6 +432,8 @@ public class HKSCS { continue; for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); + if (c == UNMAPPABLE_DECODING) + continue; int hi = c >> 8; if (c2b[hi] == C2B_UNMAPPABLE) { c2b[hi] = new char[0x100]; diff --git a/jdk/test/sun/nio/cs/TestHKSCS.java b/jdk/test/sun/nio/cs/TestHKSCS.java new file mode 100644 index 00000000000..0a7f4559d32 --- /dev/null +++ b/jdk/test/sun/nio/cs/TestHKSCS.java @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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. + * + * 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. + */ + +/* + * @test + * @bug 8166258 + * @summary Some corner cases for hkscs charsets + * @modules jdk.charsets + * @run main TestHKSCS + */ + +import java.util.Arrays; + +public class TestHKSCS { + public static void main(String args[]) throws Exception { + String[] charsets = { "x-MS950-HKSCS-XP", + "x-MS950-HKSCS", + "Big5-HKSCS", + "x-Big5-HKSCS-2001" + }; + String s = "\ufffd\ud87f\udffd"; + byte[] bytes = new byte[] { 0x3f, 0x3f }; + for (String cs : charsets) { + if (!Arrays.equals(bytes, s.getBytes(cs))) { + throw new RuntimeException(cs + " failed to decode u+fffd"); + } + } + } +} From 8630709b199e6eb4e3aa928c734bbba70ba3aa37 Mon Sep 17 00:00:00 2001 From: Steve Drach Date: Thu, 13 Oct 2016 11:54:27 -0700 Subject: [PATCH 32/43] 8167237: Jar tool can not correctly find/process the --release option if it occurs before the file list Reviewed-by: lancea --- .../sun/tools/jar/GNUStyleOptions.java | 3 +- jdk/test/tools/jar/ReleaseBeforeFiles.java | 165 ++++++++++++++++++ 2 files changed, 167 insertions(+), 1 deletion(-) create mode 100644 jdk/test/tools/jar/ReleaseBeforeFiles.java diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java index c0b58d95c46..17b4c1725cc 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/GNUStyleOptions.java @@ -254,7 +254,8 @@ class GNUStyleOptions { // process options for (; count < args.length; count++) { - if (args[count].charAt(0) != '-' || args[count].equals("-C")) + if (args[count].charAt(0) != '-' || args[count].equals("-C") + || args[count].equals("--release")) break; String name = args[count]; diff --git a/jdk/test/tools/jar/ReleaseBeforeFiles.java b/jdk/test/tools/jar/ReleaseBeforeFiles.java new file mode 100644 index 00000000000..56c27107a1b --- /dev/null +++ b/jdk/test/tools/jar/ReleaseBeforeFiles.java @@ -0,0 +1,165 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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. + * + * 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. + */ + +/* + * @test + * @bug 8167237 + * @summary test that both old style command line options and new gnu style + * command line options work with the --release option whether or + * not the --release option is preceded by a file name. + * @library /lib/testlibrary + * @modules jdk.jartool/sun.tools.jar + * @build jdk.testlibrary.FileUtils + * @run testng ReleaseBeforeFiles + */ + +import org.testng.Assert; +import org.testng.annotations.AfterMethod; +import org.testng.annotations.BeforeMethod; +import org.testng.annotations.Test; + +import java.io.IOException; +import java.io.UncheckedIOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.util.Arrays; +import java.util.stream.Stream; + +import jdk.testlibrary.FileUtils; + +public class ReleaseBeforeFiles { + private Runnable onCompletion; + + @BeforeMethod + public void reset() { + onCompletion = null; + } + + @AfterMethod + public void run() { + if (onCompletion != null) { + onCompletion.run(); + } + } + + @Test // passes before bug fix + public void test1() throws IOException { + mkdir("test1"); + touch("test1/testfile1"); + jar("cf test.jar --release 9 test1"); + jar("tf test.jar"); + rm("test.jar test1"); + } + + @Test // fails before bug fix + public void test2() throws IOException { + System.out.println("====="); + mkdir("test1"); + touch("test1/testfile1"); + onCompletion = () -> rm("test.jar test1"); + jar("--create --file=test.jar --release 9 test1"); + jar("tf test.jar"); + } + + @Test // passes before bug fix + public void test3() throws IOException { + System.out.println("====="); + mkdir("test1"); + touch("test1/testfile1"); + jar("-cf test.jar -C test1 ."); + jar("-uf test.jar --release 9 -C test1 ."); + jar("tf test.jar"); + rm("test.jar test1"); + } + + @Test // fails before bug fix + public void test4() throws IOException { + System.out.println("====="); + mkdir("test1"); + touch("test1/testfile1"); + onCompletion = () -> rm("test.jar test1"); + jar("--create --file=test.jar -C test1 ."); + jar("--update --file=test.jar --release 9 -C test1 ."); + jar("tf test.jar"); + } + + @Test // passes before bug fix since test2 precedes --release 9 + public void test5() throws IOException { + System.out.println("====="); + mkdir("test1 test2"); + touch("test1/testfile1 test2/testfile2"); + jar("--create --file=test.jar -C test1 ."); + jar("--update --file=test.jar test2 --release 9 -C test1 ."); + jar("tf test.jar"); + rm("test.jar test1 test2"); + } + + private Stream mkpath(String... args) { + return Arrays.stream(args).map(d -> Paths.get(".", d.split("/"))); + } + + private void mkdir(String cmdline) { + System.out.println("mkdir -p " + cmdline); + mkpath(cmdline.split(" +")).forEach(p -> { + try { + Files.createDirectories(p); + } catch (IOException x) { + throw new UncheckedIOException(x); + } + }); + } + + private void touch(String cmdline) { + System.out.println("touch " + cmdline); + mkpath(cmdline.split(" +")).forEach(p -> { + try { + Files.createFile(p); + } catch (IOException x) { + throw new UncheckedIOException(x); + } + }); + } + + private void rm(String cmdline) { + System.out.println("rm -rf " + cmdline); + mkpath(cmdline.split(" +")).forEach(p -> { + try { + if (Files.isDirectory(p)) { + FileUtils.deleteFileTreeWithRetry(p); + } else { + FileUtils.deleteFileIfExistsWithRetry(p); + } + } catch (IOException x) { + throw new UncheckedIOException(x); + } + }); + } + + private void jar(String cmdline) throws IOException { + System.out.println("jar " + cmdline); + boolean ok = new sun.tools.jar.Main(System.out, System.err, "jar") + .run(cmdline.split(" +")); + Assert.assertTrue(ok); + } +} From 06ee36561b6ba1e8dd006e2b18cd107553c053ac Mon Sep 17 00:00:00 2001 From: Max Ockner Date: Thu, 13 Oct 2016 15:57:24 -0400 Subject: [PATCH 33/43] 8167446: Add back PermSize and MaxPermSize Added Permsize and MaxPermSize as obsolete options to remain indefinitely. Reviewed-by: coleenp, hseigel, lfoltan --- hotspot/src/share/vm/runtime/arguments.cpp | 2 + .../runtime/CommandLine/PermGenFlagsTest.java | 51 +++++++++++++++++++ 2 files changed, 53 insertions(+) create mode 100644 hotspot/test/runtime/CommandLine/PermGenFlagsTest.java diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index 8dc6519381d..8017e73a4ea 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -422,6 +422,8 @@ static SpecialFlag const special_jvm_flags[] = { { "UseAltSigs", JDK_Version::undefined(), JDK_Version::jdk(9), JDK_Version::jdk(10) }, { "SegmentedHeapDumpThreshold", JDK_Version::undefined(), JDK_Version::jdk(9), JDK_Version::jdk(10) }, { "PrintOopAddress", JDK_Version::undefined(), JDK_Version::jdk(9), JDK_Version::jdk(10) }, + { "PermSize", JDK_Version::undefined(), JDK_Version::jdk(8), JDK_Version::jdk(10) }, + { "MaxPermSize", JDK_Version::undefined(), JDK_Version::jdk(8), JDK_Version::jdk(10) }, #ifdef TEST_VERIFY_SPECIAL_JVM_FLAGS { "dep > obs", JDK_Version::jdk(9), JDK_Version::jdk(8), JDK_Version::undefined() }, diff --git a/hotspot/test/runtime/CommandLine/PermGenFlagsTest.java b/hotspot/test/runtime/CommandLine/PermGenFlagsTest.java new file mode 100644 index 00000000000..9a821e0059e --- /dev/null +++ b/hotspot/test/runtime/CommandLine/PermGenFlagsTest.java @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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. + * + * 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. + */ + +/* + * @test + * @bug 8167446 + * @summary Commandline options PermSize and MaxPermSize should be recognized but ignored. + * @library /test/lib + * @modules java.base/jdk.internal.misc + * java.management + * @run driver PermGenFlagsTest + */ + +import jdk.test.lib.process.OutputAnalyzer; +import jdk.test.lib.process.ProcessTools; + +public class PermGenFlagsTest { + public static void main(String[] args) throws Exception { + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-XX:PermSize=22k", + "-version"); + OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldContain("Ignoring option PermSize; support was removed in 8.0"); + output.shouldHaveExitValue(0); + + pb = ProcessTools.createJavaProcessBuilder("-XX:MaxPermSize=22k", + "-version"); + output = new OutputAnalyzer(pb.start()); + output.shouldContain("Ignoring option MaxPermSize; support was removed in 8.0"); + output.shouldHaveExitValue(0); + } +} From 43c10160d5d4c9c05a3548e94f5fa436a4cdcd90 Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:09 +0000 Subject: [PATCH 34/43] Added tag jdk-9+140 for changeset 0ffcfee0d9a9 --- .hgtags-top-repo | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags-top-repo b/.hgtags-top-repo index ec2e8625423..5e870ca8562 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -382,3 +382,4 @@ be1218f792a450dfb5d4b1f82616b9d95a6a732e jdk-9+133 d7f519b004254b19e384131d9f0d0e40e31a0fd3 jdk-9+137 67c4388142bdf58aec8fefa4475faaa8a5d7380c jdk-9+138 7dcf453eacae79ee86a6bcc75fd0b546fc99b48a jdk-9+139 +a5815c6098a241d3a1df64d22b84b3524e4a77df jdk-9+140 From 45e56e1de3d622afd8b37711d67fff1f68c860e2 Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:10 +0000 Subject: [PATCH 35/43] Added tag jdk-9+140 for changeset 522e6a7f6e61 --- corba/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/corba/.hgtags b/corba/.hgtags index c5bbcbce5a7..ba432bb63a3 100644 --- a/corba/.hgtags +++ b/corba/.hgtags @@ -382,3 +382,4 @@ aa053a3faf266c12b4fd5272da431a3e08e4a3e3 jdk-9+136 258cf18fa7fc59359b874f8743b7168dc48baf73 jdk-9+137 27bb44be32076861a0951bcefb07a1d92509a4b6 jdk-9+138 8c9da7fc5b07c606afd571c7012441b77dda83b2 jdk-9+139 +9f3fc931bc230f44f2a58d75f7f6360af98bb113 jdk-9+140 From 6813916b736eb28bba3ff195f2734fcffbecc26d Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:10 +0000 Subject: [PATCH 36/43] Added tag jdk-9+140 for changeset ddbbb16c6b6e --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index bfddfeea0ac..a9c6935b623 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -542,3 +542,4 @@ a20da289f646ee44440695b81abc0548330e4ca7 jdk-9+136 dfcbf839e299e7e2bba1da69bdb347617ea4c7e8 jdk-9+137 fc0956308c7a586267c5dd35dff74f773aa9c3eb jdk-9+138 08492e67bf3226784dab3bf9ae967382ddbc1af5 jdk-9+139 +fec31089c2ef5a12dd64f401b0bf2e00f56ee0d0 jdk-9+140 From 8ae8b955f5d87c4a8415fcd68723238d5630ac10 Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:11 +0000 Subject: [PATCH 37/43] Added tag jdk-9+140 for changeset c4036f85c0c5 --- jaxp/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jaxp/.hgtags b/jaxp/.hgtags index 4468cfb7898..7476ca4e1b3 100644 --- a/jaxp/.hgtags +++ b/jaxp/.hgtags @@ -382,3 +382,4 @@ f1eafcb0eb7182b937bc93f214d8cabd01ec4d59 jdk-9+136 a8d5fe567ae72b4931040e59dd4478363f9004f5 jdk-9+137 69c3b12ba75b2e321dee731ac545e7fbff608451 jdk-9+138 8991d71c5316bde259e6a417c1199b008ca3cdf0 jdk-9+139 +8d100cb9b04819b5bd09f33c7fd5b8628d1a456f jdk-9+140 From 81d47ef648cc3af7b0bc4ce3079d0ef5e50d84f2 Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:11 +0000 Subject: [PATCH 38/43] Added tag jdk-9+140 for changeset 9c298252e385 --- jdk/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/.hgtags b/jdk/.hgtags index 132fbb94863..3a9e6fe36d2 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -382,3 +382,4 @@ d5c70818cd8a82e76632c8c815bdb4f75f53aeaf jdk-9+132 e72df94364e3686e7d62059ce0d6b187b82da713 jdk-9+137 665096863382bf23ce891307cf2a7511e77c1c88 jdk-9+138 5518ac2f2ead5e594bd983f2047178136aafdfd0 jdk-9+139 +e93b7ea559759f036c9f69fd2ddaf47bb4e98385 jdk-9+140 From 300a236aee083061aeb4be7018ff22eb5b7b1ab7 Mon Sep 17 00:00:00 2001 From: Lana Steuck Date: Thu, 13 Oct 2016 21:01:13 +0000 Subject: [PATCH 39/43] Added tag jdk-9+140 for changeset aa60c8d89a92 --- nashorn/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/nashorn/.hgtags b/nashorn/.hgtags index cb97f97e1e4..fcf0601d977 100644 --- a/nashorn/.hgtags +++ b/nashorn/.hgtags @@ -373,3 +373,4 @@ f11b8f5c4ccbf9c87d283815abac6c0117fba3c0 jdk-9+136 17ed43add2f9e3528686cd786ae2ed49c8ed36e9 jdk-9+137 4a6ee1185fc821df063e4d1537fa7ad2ebe9eb02 jdk-9+138 e3b11296395b39bfeb3364f26c2ef77fa652e300 jdk-9+139 +785843878cf78d50cc2959ea2c5a4202bbe885b4 jdk-9+140 From 6d3fbda062c42eb6a4cdab390ae979eb4996d006 Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Thu, 13 Oct 2016 17:47:30 -0700 Subject: [PATCH 40/43] 8167957: Remove FilePermission from default policy for jdk.charsets module Reviewed-by: mchung --- jdk/src/java.base/share/lib/security/default.policy | 1 - 1 file changed, 1 deletion(-) diff --git a/jdk/src/java.base/share/lib/security/default.policy b/jdk/src/java.base/share/lib/security/default.policy index f57e67fb482..37b82049dfc 100644 --- a/jdk/src/java.base/share/lib/security/default.policy +++ b/jdk/src/java.base/share/lib/security/default.policy @@ -91,7 +91,6 @@ grant codeBase "jrt:/java.xml.ws" { }; grant codeBase "jrt:/jdk.charsets" { - permission java.io.FilePermission "${java.home}/-", "read"; permission java.util.PropertyPermission "os.name", "read"; permission java.util.PropertyPermission "sun.nio.cs.map", "read"; permission java.lang.RuntimePermission "charsetProvider"; From 445c99ec2b684ae5b0ec522eaf857715a9fc5911 Mon Sep 17 00:00:00 2001 From: Roger Riggs Date: Fri, 14 Oct 2016 17:15:11 -0400 Subject: [PATCH 41/43] 8167166: Java API docs mention a non-existent method getNanosOfSecond Reviewed-by: naoto --- jdk/src/java.base/share/classes/java/time/Instant.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/time/Instant.java b/jdk/src/java.base/share/classes/java/time/Instant.java index 3fd40d04d9c..6e0dba1d506 100644 --- a/jdk/src/java.base/share/classes/java/time/Instant.java +++ b/jdk/src/java.base/share/classes/java/time/Instant.java @@ -610,7 +610,7 @@ public final class Instant *

    * The epoch second count is a simple incrementing count of seconds where * second 0 is 1970-01-01T00:00:00Z. - * The nanosecond part of the day is returned by {@code getNanosOfSecond}. + * The nanosecond part of the day is returned by {@link #getNano}. * * @return the seconds from the epoch of 1970-01-01T00:00:00Z */ @@ -623,7 +623,7 @@ public final class Instant * of the second. *

    * The nanosecond-of-second value measures the total number of nanoseconds from - * the second returned by {@code getEpochSecond}. + * the second returned by {@link #getEpochSecond}. * * @return the nanoseconds within the second, always positive, never exceeds 999,999,999 */ From 06965a6c1c8a563903a64ed2e9484075a360bf9f Mon Sep 17 00:00:00 2001 From: Frank Yuan Date: Mon, 17 Oct 2016 10:11:50 +0800 Subject: [PATCH 42/43] 8167478: javax/xml/jaxp/unittest/parsers/Bug6341770.java failed with "java.security.AccessControlException: access denied ("java.io.FilePermission" "sko?ice")" Skip the test if the environment doesn't support non-ASCII for file name. Reviewed-by: joehw --- .../xml/jaxp/unittest/parsers/Bug6341770.java | 23 ++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/jaxp/test/javax/xml/jaxp/unittest/parsers/Bug6341770.java b/jaxp/test/javax/xml/jaxp/unittest/parsers/Bug6341770.java index 3bdff2a15ae..942e7ffaed8 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/parsers/Bug6341770.java +++ b/jaxp/test/javax/xml/jaxp/unittest/parsers/Bug6341770.java @@ -28,6 +28,7 @@ import static jaxp.library.JAXPTestUtilities.tryRunWithTmpPermission; import java.io.File; import java.io.FileWriter; import java.io.PrintWriter; +import java.nio.file.Paths; import java.util.PropertyPermission; import javax.xml.parsers.SAXParserFactory; @@ -53,8 +54,14 @@ public class Bug6341770 { // naming a file "aux" would fail on windows. @Test public void testNonAsciiURI() { + if (!isNonAsciiSupported()) { + // @bug 8167478 + // if it doesn't support non-ascii, the following test is invalid even if test is passed. + System.out.println("Current environment doesn't support non-ascii, exit the test."); + return; + } try { - File dir = new File("sko\u0159ice"); + File dir = new File(ALPHA); dir.delete(); dir.mkdir(); File main = new File(dir, "main.xml"); @@ -82,4 +89,18 @@ public class Bug6341770 { } System.out.println("OK."); } + + private boolean isNonAsciiSupported() { + // Use Paths.get method to test if the path is valid in current environment + try { + Paths.get(ALPHA); + return true; + } catch (Exception e) { + return false; + } + } + + // Select alpha because it's a very common non-ascii character in different charsets. + // That this test can run in as many as possible environments if it's possible. + private static final String ALPHA = "\u03b1"; } From 8b7cc8647320640a8766bcc96eebfed163191d92 Mon Sep 17 00:00:00 2001 From: Rachna Goel Date: Mon, 17 Oct 2016 20:13:16 +0900 Subject: [PATCH 43/43] 8167992: Update documentation of java.util.Date class Reviewed-by: okutsu, peytoia --- jdk/src/java.base/share/classes/java/util/Date.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/util/Date.java b/jdk/src/java.base/share/classes/java/util/Date.java index 017ea0fef01..bb9494766bd 100644 --- a/jdk/src/java.base/share/classes/java/util/Date.java +++ b/jdk/src/java.base/share/classes/java/util/Date.java @@ -85,12 +85,12 @@ import sun.util.calendar.ZoneInfo; * further information is the U.S. Naval Observatory, particularly * the Directorate of Time at: *

    - *     http://tycho.usno.navy.mil
    + *     http://www.usno.navy.mil
      * 
    *

    * and their definitions of "Systems of Time" at: *

    - *     http://tycho.usno.navy.mil/systime.html
    + *     http://www.usno.navy.mil/USNO/time/master-clock/systems-of-time
      * 
    *

    * In all methods of class {@code Date} that accept or return