diff --git a/langtools/make/tools/propertiesparser/parser/Message.java b/langtools/make/tools/propertiesparser/parser/Message.java index 4bfded31285..bc46f3aeb9e 100644 --- a/langtools/make/tools/propertiesparser/parser/Message.java +++ b/langtools/make/tools/propertiesparser/parser/Message.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package propertiesparser.parser; import java.util.ArrayList; diff --git a/langtools/make/tools/propertiesparser/parser/MessageFile.java b/langtools/make/tools/propertiesparser/parser/MessageFile.java index 45e3384ba72..cc4bb63b17c 100644 --- a/langtools/make/tools/propertiesparser/parser/MessageFile.java +++ b/langtools/make/tools/propertiesparser/parser/MessageFile.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package propertiesparser.parser; import java.io.*; diff --git a/langtools/make/tools/propertiesparser/parser/MessageInfo.java b/langtools/make/tools/propertiesparser/parser/MessageInfo.java index e822510a9f1..c57ccf73bfb 100644 --- a/langtools/make/tools/propertiesparser/parser/MessageInfo.java +++ b/langtools/make/tools/propertiesparser/parser/MessageInfo.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package propertiesparser.parser; import propertiesparser.parser.MessageType.CompoundType; diff --git a/langtools/make/tools/propertiesparser/parser/MessageLine.java b/langtools/make/tools/propertiesparser/parser/MessageLine.java index b7751f9978b..54eb7d741aa 100644 --- a/langtools/make/tools/propertiesparser/parser/MessageLine.java +++ b/langtools/make/tools/propertiesparser/parser/MessageLine.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package propertiesparser.parser; import java.util.regex.Pattern; diff --git a/langtools/src/java.compiler/share/classes/javax/tools/DocumentationTool.java b/langtools/src/java.compiler/share/classes/javax/tools/DocumentationTool.java index 2d11778c756..163c2a56fc3 100644 --- a/langtools/src/java.compiler/share/classes/javax/tools/DocumentationTool.java +++ b/langtools/src/java.compiler/share/classes/javax/tools/DocumentationTool.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package javax.tools; import java.io.Writer; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/ErroneousTree.java b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/ErroneousTree.java index 1ece1e62887..eb0156fecb1 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/ErroneousTree.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/ErroneousTree.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.source.doctree; import javax.tools.Diagnostic; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownBlockTagTree.java b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownBlockTagTree.java index 47739a6b791..80d93572ac2 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownBlockTagTree.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownBlockTagTree.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.source.doctree; import java.util.List; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownInlineTagTree.java b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownInlineTagTree.java index 9a0eb294976..b8cd4bdc53b 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownInlineTagTree.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/source/doctree/UnknownInlineTagTree.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.source.doctree; import java.util.List; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/source/util/DocTreePathScanner.java b/langtools/src/jdk.compiler/share/classes/com/sun/source/util/DocTreePathScanner.java index 42d8414e703..e12aea6d856 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/source/util/DocTreePathScanner.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/source/util/DocTreePathScanner.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.source.util; import com.sun.source.doctree.DocTree; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/source/util/Plugin.java b/langtools/src/jdk.compiler/share/classes/com/sun/source/util/Plugin.java index ccfacfae204..d31508a5bea 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/source/util/Plugin.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/source/util/Plugin.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.source.util; import java.util.ServiceLoader; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/ClientCodeWrapper.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/ClientCodeWrapper.java index 9284d05f6f4..439c2cce354 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/ClientCodeWrapper.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/ClientCodeWrapper.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javac.api; import java.io.File; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/DiagnosticFormatter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/DiagnosticFormatter.java index e872a6451d9..01dde614c35 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/DiagnosticFormatter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/api/DiagnosticFormatter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.api; import java.util.Locale; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/AnnoConstruct.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/AnnoConstruct.java index 899cf827655..a7488eaf352 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/AnnoConstruct.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/AnnoConstruct.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.code; import java.lang.annotation.Annotation; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeMetadata.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeMetadata.java index 71aefc3a697..3a0d10646e0 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeMetadata.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeMetadata.java @@ -1,7 +1,6 @@ /* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights - * reserved. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE - * HEADER. + * Copyright (c) 2014, 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 diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Types.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Types.java index 26fec55e56c..590ca4377c0 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Types.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Types.java @@ -597,36 +597,42 @@ public class Types { } public Type removeWildcards(Type site) { - Type capturedSite = capture(site); - if (capturedSite != site) { - Type formalInterface = site.tsym.type; - ListBuffer typeargs = new ListBuffer<>(); - List actualTypeargs = site.getTypeArguments(); - List capturedTypeargs = capturedSite.getTypeArguments(); - //simply replace the wildcards with its bound - for (Type t : formalInterface.getTypeArguments()) { - if (actualTypeargs.head.hasTag(WILDCARD)) { - WildcardType wt = (WildcardType)actualTypeargs.head; - Type bound; - switch (wt.kind) { - case EXTENDS: - case UNBOUND: - CapturedType capVar = (CapturedType)capturedTypeargs.head; - //use declared bound if it doesn't depend on formal type-args - bound = capVar.bound.containsAny(capturedSite.getTypeArguments()) ? - wt.type : capVar.bound; - break; - default: - bound = wt.type; + if (site.getTypeArguments().stream().anyMatch(t -> t.hasTag(WILDCARD))) { + //compute non-wildcard parameterization - JLS 9.9 + List actuals = site.getTypeArguments(); + List formals = site.tsym.type.getTypeArguments(); + ListBuffer targs = new ListBuffer<>(); + for (Type formal : formals) { + Type actual = actuals.head; + Type bound = formal.getUpperBound(); + if (actuals.head.hasTag(WILDCARD)) { + WildcardType wt = (WildcardType)actual; + //check that bound does not contain other formals + if (bound.containsAny(formals)) { + targs.add(wt.type); + } else { + //compute new type-argument based on declared bound and wildcard bound + switch (wt.kind) { + case UNBOUND: + targs.add(bound); + break; + case EXTENDS: + targs.add(glb(bound, wt.type)); + break; + case SUPER: + targs.add(wt.type); + break; + default: + Assert.error("Cannot get here!"); + } } - typeargs.append(bound); } else { - typeargs.append(actualTypeargs.head); + //not a wildcard - the new type argument remains unchanged + targs.add(actual); } - actualTypeargs = actualTypeargs.tail; - capturedTypeargs = capturedTypeargs.tail; + actuals = actuals.tail; } - return subst(formalInterface, formalInterface.getTypeArguments(), typeargs.toList()); + return subst(site.tsym.type, formals, targs.toList()); } else { return site; } @@ -1436,12 +1442,13 @@ public class Types { public boolean isCastable(Type t, Type s, Warner warn) { if (t == s) return true; - - if (t.isPrimitive() != s.isPrimitive()) + if (t.isPrimitive() != s.isPrimitive()) { + t = skipTypeVars(t, false); return (isConvertible(t, s, warn) || (allowObjectToPrimitiveCast && s.isPrimitive() && isSubtype(boxedClass(s).type, t))); + } if (warn != warnStack.head) { try { warnStack = warnStack.prepend(warn); diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/LambdaToMethod.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/LambdaToMethod.java index 3f53f74d04f..583a34bf8df 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/LambdaToMethod.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/LambdaToMethod.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.comp; import com.sun.tools.javac.tree.*; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java index 423adf2e121..d9c468a2d3a 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java @@ -2707,11 +2707,11 @@ public class Lower extends TreeTranslator { if (fvs.nonEmpty()) { List addedargtypes = List.nil(); for (List l = fvs; l.nonEmpty(); l = l.tail) { + final Name pName = proxyName(l.head.name); + m.capturedLocals = + m.capturedLocals.prepend((VarSymbol) + (proxies.findFirst(pName))); if (TreeInfo.isInitialConstructor(tree)) { - final Name pName = proxyName(l.head.name); - m.capturedLocals = - m.capturedLocals.append((VarSymbol) - (proxies.findFirst(pName))); added = added.prepend( initField(tree.body.pos, pName)); } diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/JRTIndex.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/JRTIndex.java index f2cf19cea61..6ca7bcda13d 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/JRTIndex.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/JRTIndex.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.file; import java.io.IOException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/Locations.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/Locations.java index b45aa9bf82f..aec0e7f552e 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/Locations.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/Locations.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.file; import java.io.File; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Profile.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Profile.java index ea97348a878..cb7c714517d 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Profile.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Profile.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.jvm; import com.sun.tools.javac.util.Context; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Arguments.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Arguments.java index 3299208bee2..af02f2261d0 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Arguments.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Arguments.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.main; import java.io.File; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Parser.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Parser.java index 5b70ad0eb3e..36508984f2d 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Parser.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Parser.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javac.parser; import com.sun.tools.javac.tree.JCTree.JCCompilationUnit; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java index 7d175f20c75..ac8c7ed1be5 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.platform; import java.io.IOException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformDescription.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformDescription.java index e74fc8e4c7f..fa1fab05401 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformDescription.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformDescription.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.platform; import java.io.Closeable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformProvider.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformProvider.java index 1fe8566a209..db273a4cbc5 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformProvider.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformProvider.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.platform; /** A collection of platform descriptions that can be selected using {@code -release name} diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformUtils.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformUtils.java index 4e1cc58e39d..e1d5b3e5510 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformUtils.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/PlatformUtils.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.platform; import com.sun.tools.javac.main.Arguments; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/sym/Profiles.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/sym/Profiles.java index 6591d95ba96..6e8d447f8c1 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/sym/Profiles.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/sym/Profiles.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.sym; import java.io.BufferedInputStream; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocCommentTable.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocCommentTable.java index 1d88afdc2ab..58dd05ec9db 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocCommentTable.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocCommentTable.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.tree; import com.sun.source.doctree.ErroneousTree; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/AbstractDiagnosticFormatter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/AbstractDiagnosticFormatter.java index 2204c10b09b..eea0528e851 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/AbstractDiagnosticFormatter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/AbstractDiagnosticFormatter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.util; import java.nio.file.Path; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/ForwardingDiagnosticFormatter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/ForwardingDiagnosticFormatter.java index eefb8f8d770..89ff5c5e1c4 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/ForwardingDiagnosticFormatter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/ForwardingDiagnosticFormatter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.util; import java.util.Set; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/Iterators.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/Iterators.java index 8595650a87a..b30af24e914 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/Iterators.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/Iterators.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.util; import java.util.Iterator; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RawDiagnosticFormatter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RawDiagnosticFormatter.java index 13c0a6339c1..8168324a3a9 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RawDiagnosticFormatter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RawDiagnosticFormatter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.util; import java.util.Collection; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RichDiagnosticFormatter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RichDiagnosticFormatter.java index 0925fd1b815..08060c583bd 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RichDiagnosticFormatter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/util/RichDiagnosticFormatter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javac.util; import java.nio.file.Path; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/LLNI.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/LLNI.java index 1f1a14e53dd..744efddc41b 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/LLNI.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/LLNI.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javah; import java.io.OutputStream; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Mangle.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Mangle.java index c02d78384d7..0ba78a16abd 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Mangle.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Mangle.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javah; import javax.lang.model.element.ExecutableElement; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/TypeSignature.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/TypeSignature.java index d199a75f799..34500138e76 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/TypeSignature.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/TypeSignature.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javah; import java.util.*; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Util.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Util.java index b0b4a658a0c..005b67958a8 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Util.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javah/Util.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.javah; import java.io.PrintWriter; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/PubApiExtractor.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/PubApiExtractor.java index a6ededfae17..2bd1cac6be5 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/PubApiExtractor.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/PubApiExtractor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012-2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2014, 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/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/client/PortFileInaccessibleException.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/client/PortFileInaccessibleException.java index 938c812e287..44d383566c6 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/client/PortFileInaccessibleException.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/client/PortFileInaccessibleException.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.client; import java.io.IOException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/FileObjectWithLocation.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/FileObjectWithLocation.java index 2cd7bbe4ab7..142363ae9c9 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/FileObjectWithLocation.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/FileObjectWithLocation.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import javax.tools.FileObject; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/JavaFileObjectWithLocation.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/JavaFileObjectWithLocation.java index 60e2d468189..63f1e16acc5 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/JavaFileObjectWithLocation.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/JavaFileObjectWithLocation.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import javax.tools.ForwardingJavaFileObject; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PathAndPackageVerifier.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PathAndPackageVerifier.java index 24e3b611f8a..6f8c6068315 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PathAndPackageVerifier.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PathAndPackageVerifier.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import java.nio.file.Path; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PooledSjavac.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PooledSjavac.java index e74026a1819..caabc38df1d 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PooledSjavac.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/PooledSjavac.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import java.io.Writer; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SjavacImpl.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SjavacImpl.java index 246bcde264f..092501b483b 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SjavacImpl.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SjavacImpl.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import java.io.IOException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SmartWriter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SmartWriter.java index 23b2f7c9cc6..0aabb65f4ce 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SmartWriter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/comp/SmartWriter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.comp; import java.io.*; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ArrayTypeDesc.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ArrayTypeDesc.java index c2fe2b94515..4d01d072069 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ArrayTypeDesc.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ArrayTypeDesc.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PrimitiveTypeDesc.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PrimitiveTypeDesc.java index 877371845b4..6061aeb4797 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PrimitiveTypeDesc.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PrimitiveTypeDesc.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubApi.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubApi.java index 5daa6e7e879..418dae42c87 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubApi.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubApi.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubMethod.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubMethod.java index 403002fc7a4..193b369ddee 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubMethod.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubMethod.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubType.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubType.java index 08e4d6ddd5e..40fe4abe9bd 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubType.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubType.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubVar.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubVar.java index 5d28730c223..bc898fa744c 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubVar.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/PubVar.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ReferenceTypeDesc.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ReferenceTypeDesc.java index 73a2af628d8..e0a309eb5d8 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ReferenceTypeDesc.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/ReferenceTypeDesc.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeDesc.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeDesc.java index 0371a6d9706..6e2c8bc3fe0 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeDesc.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeDesc.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeVarTypeDesc.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeVarTypeDesc.java index 4595271fb63..4eba926c611 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeVarTypeDesc.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/pubapi/TypeVarTypeDesc.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.pubapi; import java.io.Serializable; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/IdleResetSjavac.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/IdleResetSjavac.java index 888d6bcfe27..111d9c9ff32 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/IdleResetSjavac.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/IdleResetSjavac.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; import java.io.Writer; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/PortFileMonitor.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/PortFileMonitor.java index 91a1a4a349a..d3e68565533 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/PortFileMonitor.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/PortFileMonitor.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; import java.io.IOException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/RequestHandler.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/RequestHandler.java index dc0f1539265..253c1724a26 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/RequestHandler.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/RequestHandler.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; import static com.sun.tools.sjavac.server.SjavacServer.LINE_TYPE_RC; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Sjavac.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Sjavac.java index fcb246c491c..837fb633b33 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Sjavac.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Sjavac.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; import java.io.Writer; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/SjavacServer.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/SjavacServer.java index 27667652b29..1e506ac5275 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/SjavacServer.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/SjavacServer.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; import java.io.FileNotFoundException; diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Terminable.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Terminable.java index 0b5e51c1ebc..430f7353025 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Terminable.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/sjavac/server/Terminable.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.sjavac.server; /** diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AbstractProfileIndexWriter.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AbstractProfileIndexWriter.java index debbdadc10b..f8928c20d29 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AbstractProfileIndexWriter.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AbstractProfileIndexWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AnnotationTypeFieldWriterImpl.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AnnotationTypeFieldWriterImpl.java index 87cf3a079dc..d5b9597f281 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AnnotationTypeFieldWriterImpl.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/AnnotationTypeFieldWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/HtmlDoclet.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/HtmlDoclet.java index 0cdba5f611c..4f0ce431a67 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/HtmlDoclet.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/HtmlDoclet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.formats.html; import java.io.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/LinkInfoImpl.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/LinkInfoImpl.java index db8a2959d6e..e138aebe369 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/LinkInfoImpl.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/formats/html/LinkInfoImpl.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.doclets.formats.html; import com.sun.javadoc.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/AnnotationTypeWriter.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/AnnotationTypeWriter.java index 88e909018a3..d7ae8e335c7 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/AnnotationTypeWriter.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/AnnotationTypeWriter.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.doclets.internal.toolkit; import java.io.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ClassWriter.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ClassWriter.java index ff5c1fd0e02..332679e1769 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ClassWriter.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ClassWriter.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.doclets.internal.toolkit; import java.io.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfilePackageSummaryWriter.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfilePackageSummaryWriter.java index 3f54099f9a3..5433552eeb2 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfilePackageSummaryWriter.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfilePackageSummaryWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfileSummaryWriter.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfileSummaryWriter.java index 345383fbfff..5008dafdf26 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfileSummaryWriter.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/ProfileSummaryWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java index a1172b8bdcb..662dc16ef9e 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.builders; import java.io.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java index 5dc50010191..e6717e96b51 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.taglets; import java.util.Map; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/IndexTaglet.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/IndexTaglet.java index 5d5667edd8a..16fa05230f4 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/IndexTaglet.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/IndexTaglet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.taglets; import java.util.Map; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java index 8f3d6e6b524..2bc9f99c8ce 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.taglets; import java.util.Map; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/MessageRetriever.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/MessageRetriever.java index 75129c20a3e..e357556d5bf 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/MessageRetriever.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/MessageRetriever.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.util; import java.text.MessageFormat; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/TextTag.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/TextTag.java index 074718f7979..af0a59344fe 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/TextTag.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/doclets/internal/toolkit/util/TextTag.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.doclets.internal.toolkit.util; import com.sun.javadoc.*; diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/api/JavadocTaskImpl.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/api/JavadocTaskImpl.java index ef5703774be..18d24b1e6b5 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/api/JavadocTaskImpl.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/api/JavadocTaskImpl.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javadoc.api; import com.sun.tools.javac.util.ClientCodeException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ClassWriter.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ClassWriter.java index 7ad5822a904..903931d6496 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ClassWriter.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ClassWriter.java @@ -1,4 +1,3 @@ - /* * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. @@ -24,6 +23,7 @@ * questions. */ + package com.sun.tools.classfile; import java.io.ByteArrayOutputStream; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/CompilationID_attribute.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/CompilationID_attribute.java index 22ef158fd57..6f2d70508b3 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/CompilationID_attribute.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/CompilationID_attribute.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.classfile; import java.io.IOException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ConstantPoolException.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ConstantPoolException.java index 15b5298322d..50a9e9b8d88 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ConstantPoolException.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/ConstantPoolException.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.classfile; /* diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Dependencies.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Dependencies.java index 5c63ee1747f..c6fe442e9e3 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Dependencies.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Dependencies.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.classfile; import java.util.Deque; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Descriptor.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Descriptor.java index 0e340e06ad9..fed0f3010a9 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Descriptor.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/Descriptor.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.classfile; import java.io.IOException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/DescriptorException.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/DescriptorException.java index 92494366abc..0a91e36a914 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/DescriptorException.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/DescriptorException.java @@ -23,7 +23,6 @@ * questions. */ - package com.sun.tools.classfile; /* diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java index bdebe41e586..4cbf1eba912 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java @@ -1,4 +1,3 @@ - /* * Copyright (c) 2007, 2008, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. @@ -24,6 +23,7 @@ * questions. */ + package com.sun.tools.classfile; import java.io.IOException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/SourceID_attribute.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/SourceID_attribute.java index 8b00ffe7db2..d8c1e523c9d 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/SourceID_attribute.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/classfile/SourceID_attribute.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.classfile; import java.io.IOException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/javap/TypeAnnotationWriter.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/javap/TypeAnnotationWriter.java index 1d0e31bffbe..180c995557e 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/javap/TypeAnnotationWriter.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/javap/TypeAnnotationWriter.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.javap; import com.sun.tools.classfile.Attribute; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Analyzer.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Analyzer.java index 4cb7e8ffbce..88ee11b022f 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Analyzer.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Analyzer.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import java.io.PrintStream; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Archive.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Archive.java index 74b7b57e862..e6a18f5dd99 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Archive.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Archive.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import com.sun.tools.classfile.ClassFile; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ClassFileReader.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ClassFileReader.java index dc1bd2cb068..f849b323556 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ClassFileReader.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ClassFileReader.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import com.sun.tools.classfile.ClassFile; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/JdepsTask.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/JdepsTask.java index c76bc6c3ea8..2c6268343a7 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/JdepsTask.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/JdepsTask.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import com.sun.tools.classfile.AccessFlags; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Module.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Module.java index f09fa8fe84c..9da197e4b34 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Module.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Module.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import java.util.Collections; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ModulesXmlReader.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ModulesXmlReader.java index 93635ea0542..be9d3d3a6e1 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ModulesXmlReader.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/ModulesXmlReader.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import java.io.IOException; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/PlatformClassPath.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/PlatformClassPath.java index ba83e3dd5eb..6142b4bd3f6 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/PlatformClassPath.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/PlatformClassPath.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import com.sun.tools.classfile.ClassFile; diff --git a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Profile.java b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Profile.java index ebf876a5def..bd70ec841b1 100644 --- a/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Profile.java +++ b/langtools/src/jdk.jdeps/share/classes/com/sun/tools/jdeps/Profile.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package com.sun.tools.jdeps; import java.io.IOException; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/remote/RemoteCodes.java b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/remote/RemoteCodes.java index 0f26b7914d5..edb33f0bd38 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/remote/RemoteCodes.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/remote/RemoteCodes.java @@ -23,7 +23,6 @@ * questions. */ - package jdk.internal.jshell.remote; import java.util.regex.Pattern; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/EditingHistory.java b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/EditingHistory.java index ae1326534a5..d6ec9d5af3c 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/EditingHistory.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/EditingHistory.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.internal.jshell.tool; import java.util.ArrayList; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java index 1c3e1861f5a..94c16f1e0c3 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.internal.jshell.tool; import java.io.IOException; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/DeclarationSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/DeclarationSnippet.java index c654964b244..8fc60cb749d 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/DeclarationSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/DeclarationSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.Collection; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ErroneousSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ErroneousSnippet.java index 1a6ca62c3ae..c1b725b7436 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ErroneousSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ErroneousSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import jdk.jshell.Key.ErroneousKey; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Eval.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Eval.java index 212bb9e0f3f..ae011111070 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Eval.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Eval.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.ArrayList; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExecutionControl.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExecutionControl.java index 3753ea8b84c..6e6b02ae9b9 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExecutionControl.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExecutionControl.java @@ -33,6 +33,7 @@ import java.net.ServerSocket; import java.net.Socket; import com.sun.jdi.*; import java.io.EOFException; +import java.util.HashMap; import java.util.List; import java.util.Map; import jdk.jshell.ClassTracker.ClassInfo; @@ -247,17 +248,18 @@ class ExecutionControl { //MessageOutput.textResources = ResourceBundle.getBundle("impl.TTYResources", // Locale.getDefault()); - String connect = "com.sun.jdi.CommandLineLaunch:"; - String cmdLine = "jdk.internal.jshell.remote.RemoteAgent"; + String connectorName = "com.sun.jdi.CommandLineLaunch"; String classPath = System.getProperty("java.class.path"); String bootclassPath = System.getProperty("sun.boot.class.path"); - String javaArgs = "-classpath " + classPath + " -Xbootclasspath:" + bootclassPath; + String javaArgs = "-classpath \"" + classPath + "\" -Xbootclasspath:\"" + bootclassPath + "\""; + Map argumentName2Value = new HashMap<>(); + argumentName2Value.put("main", "jdk.internal.jshell.remote.RemoteAgent " + port); + argumentName2Value.put("options", javaArgs); - String connectSpec = connect + "main=" + cmdLine + " " + port + ",options=" + javaArgs + ","; boolean launchImmediately = true; int traceFlags = 0;// VirtualMachine.TRACE_SENDS | VirtualMachine.TRACE_EVENTS; - env.init(connectSpec, launchImmediately, traceFlags); + env.init(connectorName, argumentName2Value, launchImmediately, traceFlags); if (env.connection().isOpen() && env.vm().canBeModified()) { /* diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExpressionSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExpressionSnippet.java index 6934bee687d..97a421cde1f 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExpressionSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ExpressionSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import jdk.jshell.Key.ExpressionKey; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ImportSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ImportSnippet.java index c598442a387..d906b39d8c2 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ImportSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ImportSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import jdk.jshell.Key.ImportKey; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIConnection.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIConnection.java index 663eb206164..d1a68130c67 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIConnection.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIConnection.java @@ -38,8 +38,9 @@ import com.sun.jdi.*; import com.sun.jdi.connect.*; import java.util.*; -import java.util.regex.*; +import java.util.Map.Entry; import java.io.*; + import static jdk.internal.jshell.debug.InternalDebugControl.DBG_GEN; /** @@ -83,239 +84,35 @@ class JDIConnection { return null; } - private Map parseConnectorArgs(Connector connector, String argString) { - Map arguments = connector.defaultArguments(); - - /* - * We are parsing strings of the form: - * name1=value1,[name2=value2,...] - * However, the value1...valuen substrings may contain - * embedded comma(s), so make provision for quoting inside - * the value substrings. (Bug ID 4285874) - */ - String regexPattern = - "(quote=[^,]+,)|" + // special case for quote=., - "(\\w+=)" + // name= - "(((\"[^\"]*\")|" + // ( "l , ue" - "('[^']*')|" + // 'l , ue' - "([^,'\"]+))+,)"; // v a l u e )+ , - Pattern p = Pattern.compile(regexPattern); - Matcher m = p.matcher(argString); - while (m.find()) { - int startPosition = m.start(); - int endPosition = m.end(); - if (startPosition > 0) { - /* - * It is an error if parsing skips over any part of argString. - */ - throw new IllegalArgumentException("Illegal connector argument" + - argString); - } - - String token = argString.substring(startPosition, endPosition); - int index = token.indexOf('='); - String name = token.substring(0, index); - String value = token.substring(index + 1, - token.length() - 1); // Remove comma delimiter - - /* - * for values enclosed in quotes (single and/or double quotes) - * strip off enclosing quote chars - * needed for quote enclosed delimited substrings - */ - if (name.equals("options")) { - StringBuilder sb = new StringBuilder(); - for (String s : splitStringAtNonEnclosedWhiteSpace(value)) { - while (isEnclosed(s, "\"") || isEnclosed(s, "'")) { - s = s.substring(1, s.length() - 1); - } - sb.append(s); - sb.append(" "); - } - value = sb.toString(); - } + private Map mergeConnectorArgs(Connector connector, Map argumentName2Value) { + Map arguments = connector.defaultArguments(); + for (Entry argumentEntry : argumentName2Value.entrySet()) { + String name = argumentEntry.getKey(); + String value = argumentEntry.getValue(); Connector.Argument argument = arguments.get(name); + if (argument == null) { throw new IllegalArgumentException("Argument is not defined for connector:" + name + " -- " + connector.name()); } - argument.setValue(value); - argString = argString.substring(endPosition); // Remove what was just parsed... - m = p.matcher(argString); // and parse again on what is left. - } - if ((! argString.equals(",")) && (argString.length() > 0)) { - /* - * It is an error if any part of argString is left over, - * unless it was empty to begin with. - */ - throw new IllegalArgumentException("Illegal connector argument" + argString); + argument.setValue(value); } + return arguments; } - private static boolean isEnclosed(String value, String enclosingChar) { - if (value.indexOf(enclosingChar) == 0) { - int lastIndex = value.lastIndexOf(enclosingChar); - if (lastIndex > 0 && lastIndex == value.length() - 1) { - return true; - } - } - return false; - } - - private static List splitStringAtNonEnclosedWhiteSpace(String value) throws IllegalArgumentException { - List al = new ArrayList<>(); - char[] arr; - int startPosition = 0; - int endPosition; - final char SPACE = ' '; - final char DOUBLEQ = '"'; - final char SINGLEQ = '\''; - - /* - * An "open" or "active" enclosing state is where - * the first valid start quote qualifier is found, - * and there is a search in progress for the - * relevant end matching quote - * - * enclosingTargetChar set to SPACE - * is used to signal a non open enclosing state - */ - char enclosingTargetChar = SPACE; - - if (value == null) { - throw new IllegalArgumentException("value string is null"); - } - - // split parameter string into individual chars - arr = value.toCharArray(); - - for (int i = 0; i < arr.length; i++) { - switch (arr[i]) { - case SPACE: { - // do nothing for spaces - // unless last in array - if (isLastChar(arr, i)) { - endPosition = i; - // break for substring creation - break; - } - continue; - } - case DOUBLEQ: - case SINGLEQ: { - if (enclosingTargetChar == arr[i]) { - // potential match to close open enclosing - if (isNextCharWhitespace(arr, i)) { - // if peek next is whitespace - // then enclosing is a valid substring - endPosition = i; - // reset enclosing target char - enclosingTargetChar = SPACE; - // break for substring creation - break; - } - } - if (enclosingTargetChar == SPACE) { - // no open enclosing state - // handle as normal char - if (isPreviousCharWhitespace(arr, i)) { - startPosition = i; - // peek forward for end candidates - if (value.indexOf(arr[i], i + 1) >= 0) { - // set open enclosing state by - // setting up the target char - enclosingTargetChar = arr[i]; - } else { - // no more target chars left to match - // end enclosing, handle as normal char - if (isNextCharWhitespace(arr, i)) { - endPosition = i; - // break for substring creation - break; - } - } - } - } - continue; - } - default: { - // normal non-space, non-" and non-' chars - if (enclosingTargetChar == SPACE) { - // no open enclosing state - if (isPreviousCharWhitespace(arr, i)) { - // start of space delim substring - startPosition = i; - } - if (isNextCharWhitespace(arr, i)) { - // end of space delim substring - endPosition = i; - // break for substring creation - break; - } - } - continue; - } - } - - // break's end up here - if (startPosition > endPosition) { - throw new IllegalArgumentException("Illegal option values"); - } - - // extract substring and add to List - al.add(value.substring(startPosition, ++endPosition)); - - // set new start position - i = startPosition = endPosition; - - } // for loop - - return al; - } - - static private boolean isPreviousCharWhitespace(char[] arr, int curr_pos) { - return isCharWhitespace(arr, curr_pos - 1); - } - - static private boolean isNextCharWhitespace(char[] arr, int curr_pos) { - return isCharWhitespace(arr, curr_pos + 1); - } - - static private boolean isCharWhitespace(char[] arr, int pos) { - if (pos < 0 || pos >= arr.length) { - // outside arraybounds is considered an implicit space - return true; - } - return (arr[pos] == ' '); - } - - static private boolean isLastChar(char[] arr, int pos) { - return (pos + 1 == arr.length); - } - - JDIConnection(JDIEnv env, String connectSpec, int traceFlags, JShell proc) { + JDIConnection(JDIEnv env, String connectorName, Map argumentName2Value, int traceFlags, JShell proc) { this.env = env; this.proc = proc; - String nameString; - String argString; - int index = connectSpec.indexOf(':'); - if (index == -1) { - nameString = connectSpec; - argString = ""; - } else { - nameString = connectSpec.substring(0, index); - argString = connectSpec.substring(index + 1); - } + this.connector = findConnector(connectorName); - connector = findConnector(nameString); if (connector == null) { - throw new IllegalArgumentException("No connector named: " + nameString); + throw new IllegalArgumentException("No connector named: " + connectorName); } - connectorArgs = parseConnectorArgs(connector, argString); + connectorArgs = mergeConnectorArgs(connector, argumentName2Value); this.traceFlags = traceFlags; } diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEnv.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEnv.java index 6ec78d775a9..e280ade958a 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEnv.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEnv.java @@ -25,6 +25,8 @@ package jdk.jshell; +import java.util.Map; + import com.sun.jdi.*; import static jdk.internal.jshell.debug.InternalDebugControl.DBG_GEN; @@ -41,8 +43,8 @@ class JDIEnv { this.state = state; } - void init(String connectSpec, boolean openNow, int flags) { - connection = new JDIConnection(this, connectSpec, flags, state); + void init(String connectorName, Map argumentName2Value, boolean openNow, int flags) { + connection = new JDIConnection(this, connectorName, argumentName2Value, flags, state); if (!connection.isLaunch() || openNow) { connection.open(); } diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEventHandler.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEventHandler.java index adbf42838c1..fc18b1e4e81 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEventHandler.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/JDIEventHandler.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2011, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2014, 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/langtools/src/jdk.jshell/share/classes/jdk/jshell/MaskCommentsAndModifiers.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/MaskCommentsAndModifiers.java index da4665d9852..8ea85121986 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/MaskCommentsAndModifiers.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/MaskCommentsAndModifiers.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.Set; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/MethodSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/MethodSnippet.java index e70757085d5..5ec1e55907f 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/MethodSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/MethodSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.Collection; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/OuterWrap.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/OuterWrap.java index 2d08f38a5d8..8892b54c964 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/OuterWrap.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/OuterWrap.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import jdk.jshell.Wrap.CompoundWrap; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/PersistentSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/PersistentSnippet.java index 84a9fa7a5c4..e571a846a64 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/PersistentSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/PersistentSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; /** diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParser.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParser.java index 7411ec985a4..5712a2202fe 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParser.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParser.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import com.sun.tools.javac.code.TypeTag; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParserFactory.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParserFactory.java index 14299737a8d..018d39153d6 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParserFactory.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/ReplParserFactory.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import com.sun.tools.javac.parser.JavacParser; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/StatementSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/StatementSnippet.java index ace8d31fe76..d227b5483d2 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/StatementSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/StatementSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import jdk.jshell.Key.StatementKey; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypeDeclSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypeDeclSnippet.java index 6d29087e95b..c35937fee42 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypeDeclSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypeDeclSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.Collection; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypePrinter.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypePrinter.java index 2ac9530f0a6..e35fe5e7d7b 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypePrinter.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/TypePrinter.java @@ -41,15 +41,15 @@ import java.util.function.BinaryOperator; * Print types in source form. */ class TypePrinter extends Printer { + private static final String OBJECT = "Object"; private final JavacMessages messages; private final BinaryOperator fullClassNameAndPackageToClass; - private final Type typeToPrint; + private boolean useWildCard = false; TypePrinter(JavacMessages messages, BinaryOperator fullClassNameAndPackageToClass, Type typeToPrint) { this.messages = messages; this.fullClassNameAndPackageToClass = fullClassNameAndPackageToClass; - this.typeToPrint = typeToPrint; } @Override @@ -64,21 +64,40 @@ class TypePrinter extends Printer { @Override public String visitCapturedType(Type.CapturedType t, Locale locale) { - if (t == typeToPrint) { - return visit(t.getUpperBound(), locale); - } else { - return visit(t.wildcard, locale); + return visit(t.wildcard, locale); + } + + @Override + public String visitWildcardType(Type.WildcardType wt, Locale locale) { + if (useWildCard) { // at TypeArgument(ex: List) + return super.visitWildcardType(wt, locale); + } else { // at TopLevelType(ex: ? extends List, ? extends Number[][]) + Type extendsBound = wt.getExtendsBound(); + return extendsBound == null + ? OBJECT + : visit(extendsBound, locale); } } @Override public String visitType(Type t, Locale locale) { String s = (t.tsym == null || t.tsym.name == null) - ? "Object" // none + ? OBJECT // none : t.tsym.name.toString(); return s; } + @Override + public String visitClassType(ClassType ct, Locale locale) { + boolean prevUseWildCard = useWildCard; + try { + useWildCard = true; + return super.visitClassType(ct, locale); + } finally { + useWildCard = prevUseWildCard; + } + } + /** * Converts a class name into a (possibly localized) string. Anonymous * inner classes get converted into a localized string. @@ -101,7 +120,7 @@ class TypePrinter extends Printer { } return s.toString(); ***/ - return "Object"; + return OBJECT; } else if (sym.name.length() == 0) { // Anonymous String s; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Util.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Util.java index c41c04f4e7c..00b16d88ff3 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Util.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Util.java @@ -1,4 +1,4 @@ - /* +/* * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/VarSnippet.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/VarSnippet.java index 8b93fab37dc..f979b225967 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/VarSnippet.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/VarSnippet.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.Collection; diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Wrap.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Wrap.java index aba8051bff4..1b380444936 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/Wrap.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/Wrap.java @@ -22,6 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package jdk.jshell; import java.util.ArrayList; diff --git a/langtools/test/com/sun/javadoc/T6735320/SerialFieldTest.java b/langtools/test/com/sun/javadoc/T6735320/SerialFieldTest.java index c20849ff9f0..31f60ee247b 100644 --- a/langtools/test/com/sun/javadoc/T6735320/SerialFieldTest.java +++ b/langtools/test/com/sun/javadoc/T6735320/SerialFieldTest.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.io.ObjectStreamField; import java.io.Serializable; diff --git a/langtools/test/com/sun/javadoc/testCmndLineClass/C5.java b/langtools/test/com/sun/javadoc/testCmndLineClass/C5.java index 2ccc19f0279..be24cc60132 100644 --- a/langtools/test/com/sun/javadoc/testCmndLineClass/C5.java +++ b/langtools/test/com/sun/javadoc/testCmndLineClass/C5.java @@ -21,7 +21,6 @@ * questions. */ - /** *This is a description for C5. */ diff --git a/langtools/test/com/sun/javadoc/testEncoding/EncodeTest.java b/langtools/test/com/sun/javadoc/testEncoding/EncodeTest.java index 393ba8f5de2..da11306c5cf 100644 --- a/langtools/test/com/sun/javadoc/testEncoding/EncodeTest.java +++ b/langtools/test/com/sun/javadoc/testEncoding/EncodeTest.java @@ -21,7 +21,6 @@ * questions. */ - /** * Testing en\u00e7\u00f4ded string. * In the encoded comment string, Unicode U+00E7 is "Latin small letter C with cedilla" diff --git a/langtools/test/com/sun/javadoc/testJavaFX/pkg1/C.java b/langtools/test/com/sun/javadoc/testJavaFX/pkg1/C.java index 09d6552c675..060bb7a356f 100644 --- a/langtools/test/com/sun/javadoc/testJavaFX/pkg1/C.java +++ b/langtools/test/com/sun/javadoc/testJavaFX/pkg1/C.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; public class C { diff --git a/langtools/test/com/sun/javadoc/testJavaFX/pkg1/D.java b/langtools/test/com/sun/javadoc/testJavaFX/pkg1/D.java index c1fb6dba1ed..77953add545 100644 --- a/langtools/test/com/sun/javadoc/testJavaFX/pkg1/D.java +++ b/langtools/test/com/sun/javadoc/testJavaFX/pkg1/D.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; public class D extends C {} diff --git a/langtools/test/com/sun/javadoc/testJavaFX/pkg2/Test.java b/langtools/test/com/sun/javadoc/testJavaFX/pkg2/Test.java index 1673cd159b4..9e1973d944c 100644 --- a/langtools/test/com/sun/javadoc/testJavaFX/pkg2/Test.java +++ b/langtools/test/com/sun/javadoc/testJavaFX/pkg2/Test.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg2; import java.util.List; diff --git a/langtools/test/com/sun/javadoc/testLegacyTaglet/C.java b/langtools/test/com/sun/javadoc/testLegacyTaglet/C.java index cdf435cb539..f4dbce77af1 100644 --- a/langtools/test/com/sun/javadoc/testLegacyTaglet/C.java +++ b/langtools/test/com/sun/javadoc/testLegacyTaglet/C.java @@ -21,7 +21,6 @@ * questions. */ - /** * This is an {@underline underline}. * @todo Finish this class. diff --git a/langtools/test/com/sun/javadoc/testOrdering/pkg1/A.java b/langtools/test/com/sun/javadoc/testOrdering/pkg1/A.java index ce651c74611..56a6bc669d7 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/pkg1/A.java +++ b/langtools/test/com/sun/javadoc/testOrdering/pkg1/A.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; import java.util.Collection; import java.util.List; diff --git a/langtools/test/com/sun/javadoc/testOrdering/pkg1/B.java b/langtools/test/com/sun/javadoc/testOrdering/pkg1/B.java index dc332949dc8..7f91bebc2cd 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/pkg1/B.java +++ b/langtools/test/com/sun/javadoc/testOrdering/pkg1/B.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; public class B { diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/a/A.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/a/A.java index 603bfc12ff5..fe0ee6c4b20 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/a/A.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/a/A.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package a; /** * A class diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/a/something.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/a/something.java index 9869b22bd98..c0e521c9bbc 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/a/something.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/a/something.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package a; /** * A class diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/b/B.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/b/B.java index 5eea0f5de3d..524b69280b4 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/b/B.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/b/B.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package b; /** * Another class diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/b/something.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/b/something.java index ea8726d2057..e9c5ae015ae 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/b/something.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/b/something.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package b; /** * an annotation diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/e/something.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/e/something.java index 0120a2e84fa..8ef92368cf3 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/e/something.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/e/something.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package e; /** * An enum diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/J.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/J.java index bc1da1fea79..499106d5f60 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/J.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/J.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package something; public class J { /** diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/package-info.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/package-info.java index f712a9fb5ab..2ceca414974 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/package-info.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/package-info.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + /** * A package */ diff --git a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/something.java b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/something.java index 890e0c5d2bc..d9c6fd194df 100644 --- a/langtools/test/com/sun/javadoc/testOrdering/src-2/something/something.java +++ b/langtools/test/com/sun/javadoc/testOrdering/src-2/something/something.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package something; /** * An interface diff --git a/langtools/test/com/sun/javadoc/testSearch/pkgfx/C.java b/langtools/test/com/sun/javadoc/testSearch/pkgfx/C.java index b1688f6ba7a..7f416f50042 100644 --- a/langtools/test/com/sun/javadoc/testSearch/pkgfx/C.java +++ b/langtools/test/com/sun/javadoc/testSearch/pkgfx/C.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkgfx; public class C { diff --git a/langtools/test/com/sun/javadoc/testSinceTag/pkg1/C1.java b/langtools/test/com/sun/javadoc/testSinceTag/pkg1/C1.java index dff72941c09..32cb3bdec49 100644 --- a/langtools/test/com/sun/javadoc/testSinceTag/pkg1/C1.java +++ b/langtools/test/com/sun/javadoc/testSinceTag/pkg1/C1.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; import java.io.IOException; diff --git a/langtools/test/com/sun/javadoc/testThrowsInheritence/C.java b/langtools/test/com/sun/javadoc/testThrowsInheritence/C.java index 66318a4cb21..a308da62da5 100644 --- a/langtools/test/com/sun/javadoc/testThrowsInheritence/C.java +++ b/langtools/test/com/sun/javadoc/testThrowsInheritence/C.java @@ -21,7 +21,6 @@ * questions. */ - public class C implements I { /** diff --git a/langtools/test/com/sun/javadoc/testThrowsInheritence/I.java b/langtools/test/com/sun/javadoc/testThrowsInheritence/I.java index e5c359893a3..2db7dbaa724 100644 --- a/langtools/test/com/sun/javadoc/testThrowsInheritence/I.java +++ b/langtools/test/com/sun/javadoc/testThrowsInheritence/I.java @@ -21,7 +21,6 @@ * questions. */ - public interface I { /** * @throws java.lang.NullPointerException Test 1 fails diff --git a/langtools/test/com/sun/javadoc/testTypeAnnotations/typeannos/Varargs.java b/langtools/test/com/sun/javadoc/testTypeAnnotations/typeannos/Varargs.java index bb956e80a92..37f79f00d76 100644 --- a/langtools/test/com/sun/javadoc/testTypeAnnotations/typeannos/Varargs.java +++ b/langtools/test/com/sun/javadoc/testTypeAnnotations/typeannos/Varargs.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package typeannos; import java.lang.annotation.*; diff --git a/langtools/test/com/sun/javadoc/testUseOption/pkg1/AnAbstract.java b/langtools/test/com/sun/javadoc/testUseOption/pkg1/AnAbstract.java index 00b5d40f117..4d31c6f36bd 100644 --- a/langtools/test/com/sun/javadoc/testUseOption/pkg1/AnAbstract.java +++ b/langtools/test/com/sun/javadoc/testUseOption/pkg1/AnAbstract.java @@ -20,5 +20,6 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg1; public abstract class AnAbstract implements UsedInterface {} diff --git a/langtools/test/jdk/jshell/TypeNameTest.java b/langtools/test/jdk/jshell/TypeNameTest.java index 41dbe7004cb..4f1b9cef418 100644 --- a/langtools/test/jdk/jshell/TypeNameTest.java +++ b/langtools/test/jdk/jshell/TypeNameTest.java @@ -23,7 +23,8 @@ /* * @test - * @summary null test + * @bug 8144903 + * @summary Tests for determining the type from the expression * @build KullaTesting TestingInputStream * @run testng TypeNameTest */ @@ -34,7 +35,6 @@ import org.testng.annotations.Test; import static jdk.jshell.Snippet.Status.VALID; import static org.testng.Assert.assertEquals; -import static jdk.jshell.Snippet.Status.OVERWRITTEN; @Test public class TypeNameTest extends KullaTesting { @@ -62,6 +62,11 @@ public class TypeNameTest extends KullaTesting { assertEquals(sn.typeName(), "Class"); } + public void testArrayTypeOfCapturedTypeName() { + VarSnippet sn = (VarSnippet) varKey(assertEval("\"\".getClass().getEnumConstants();")); + assertEquals(sn.typeName(), "String[]"); + } + public void testJavaLang() { VarSnippet sn = (VarSnippet) varKey(assertEval("\"\";")); assertEquals(sn.typeName(), "String"); @@ -83,14 +88,16 @@ public class TypeNameTest extends KullaTesting { VarSnippet sn3 = (VarSnippet) varKey(assertEval("list3.iterator().next()")); assertEquals(sn3.typeName(), "Object"); assertEval("class Test1 { public X get() { return null; } }"); - Snippet x = varKey(assertEval("Test1 x = new Test1<>();")); - VarSnippet sn4 = (VarSnippet) varKey(assertEval("x.get()")); - assertEquals(sn4.typeName(), "CharSequence"); - assertEval("class Foo { public X get() { return null; } }"); - assertEval("Foo x = new Foo<>();", - ste(MAIN_SNIPPET, VALID, VALID, true, null), - ste(x, VALID, OVERWRITTEN, false, MAIN_SNIPPET)); - VarSnippet sn5 = (VarSnippet) varKey(assertEval("x.get()")); + Snippet x = varKey(assertEval("Test1 test1 = new Test1<>();")); + VarSnippet sn4 = (VarSnippet) varKey(assertEval("test1.get()")); + assertEquals(sn4.typeName(), "Object"); + assertEval("class Test2 { public X get() { return null; } }"); + assertEval("Test2 test2 = new Test2<>();"); + VarSnippet sn5 = (VarSnippet) varKey(assertEval("test2.get()")); assertEquals(sn5.typeName(), "Object"); + assertEval("class Test3 { T[][] get() { return null; } }", added(VALID)); + assertEval("Test3 test3 = new Test3<>();"); + VarSnippet sn6 = (VarSnippet) varKey(assertEval("test3.get()")); + assertEquals(sn6.typeName(), "String[][]"); } } diff --git a/langtools/test/jdk/jshell/VariablesTest.java b/langtools/test/jdk/jshell/VariablesTest.java index 73a25a372c1..3a374a0b52c 100644 --- a/langtools/test/jdk/jshell/VariablesTest.java +++ b/langtools/test/jdk/jshell/VariablesTest.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8144903 * @summary Tests for EvaluationState.variables * @build KullaTesting TestingInputStream ExpectedDiagnostic * @run testng VariablesTest @@ -184,6 +185,16 @@ public class VariablesTest extends KullaTesting { assertActiveKeys(); } + public void variablesTemporaryArrayOfCapturedType() { + assertEval("class Test { T[][] get() { return null; } }", added(VALID)); + assertEval("Test test() { return new Test<>(); }", added(VALID)); + assertEval("test().get()", added(VALID)); + assertVariables(variable("String[][]", "$1")); + assertEval("\"\".getClass().getEnumConstants()", added(VALID)); + assertVariables(variable("String[][]", "$1"), variable("String[]", "$2")); + assertActiveKeys(); + } + public void variablesClassReplace() { assertEval("import java.util.*;", added(VALID)); Snippet var = varKey(assertEval("List list = new ArrayList<>();", "[]", diff --git a/langtools/test/lib/combo/tools/javac/combo/Diagnostics.java b/langtools/test/lib/combo/tools/javac/combo/Diagnostics.java index 6f1774d6572..0246fde7dc4 100644 --- a/langtools/test/lib/combo/tools/javac/combo/Diagnostics.java +++ b/langtools/test/lib/combo/tools/javac/combo/Diagnostics.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package tools.javac.combo; import javax.tools.Diagnostic; diff --git a/langtools/test/lib/combo/tools/javac/combo/JavacTemplateTestBase.java b/langtools/test/lib/combo/tools/javac/combo/JavacTemplateTestBase.java index 7c045fc1890..6022d22f383 100644 --- a/langtools/test/lib/combo/tools/javac/combo/JavacTemplateTestBase.java +++ b/langtools/test/lib/combo/tools/javac/combo/JavacTemplateTestBase.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package tools.javac.combo; import java.io.File; diff --git a/langtools/test/lib/combo/tools/javac/combo/Template.java b/langtools/test/lib/combo/tools/javac/combo/Template.java index ad8aeb9f956..0f804c8bab2 100644 --- a/langtools/test/lib/combo/tools/javac/combo/Template.java +++ b/langtools/test/lib/combo/tools/javac/combo/Template.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package tools.javac.combo; import java.util.Map; diff --git a/langtools/test/lib/combo/tools/javac/combo/TemplateTest.java b/langtools/test/lib/combo/tools/javac/combo/TemplateTest.java index 356456872dd..2bb950b7993 100644 --- a/langtools/test/lib/combo/tools/javac/combo/TemplateTest.java +++ b/langtools/test/lib/combo/tools/javac/combo/TemplateTest.java @@ -19,8 +19,8 @@ * 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 tools.javac.combo; import org.testng.annotations.BeforeTest; diff --git a/langtools/test/tools/doclint/tidy/util/Main.java b/langtools/test/tools/doclint/tidy/util/Main.java index 77b356f1d2e..42fd38bf17d 100644 --- a/langtools/test/tools/doclint/tidy/util/Main.java +++ b/langtools/test/tools/doclint/tidy/util/Main.java @@ -21,7 +21,6 @@ * questions. */ - package tidystats; import java.io.IOException; diff --git a/langtools/test/tools/javac/6199662/TreeInfo.java b/langtools/test/tools/javac/6199662/TreeInfo.java index 3d56ad84e34..6e1ed0a90dd 100644 --- a/langtools/test/tools/javac/6199662/TreeInfo.java +++ b/langtools/test/tools/javac/6199662/TreeInfo.java @@ -21,7 +21,6 @@ * questions. */ - package p; import p.Tree.*; diff --git a/langtools/test/tools/javac/6199662/TreeScanner.java b/langtools/test/tools/javac/6199662/TreeScanner.java index cfd0c4d9fed..f6bfb78ee58 100644 --- a/langtools/test/tools/javac/6199662/TreeScanner.java +++ b/langtools/test/tools/javac/6199662/TreeScanner.java @@ -21,7 +21,6 @@ * questions. */ - package p; import p.Tree.*; diff --git a/langtools/test/tools/javac/6302184/T6302184.java b/langtools/test/tools/javac/6302184/T6302184.java index cc6737a56a0..45f7d53d869 100644 --- a/langtools/test/tools/javac/6302184/T6302184.java +++ b/langtools/test/tools/javac/6302184/T6302184.java @@ -21,7 +21,6 @@ * questions. */ - /** * This is a test that uses ISO 8859 encoding. */ diff --git a/langtools/test/tools/javac/6400872/C.java b/langtools/test/tools/javac/6400872/C.java index 4f8050d9259..f922c519a18 100644 --- a/langtools/test/tools/javac/6400872/C.java +++ b/langtools/test/tools/javac/6400872/C.java @@ -21,8 +21,6 @@ * questions. */ - - class C { A a = new A(); B b = new B(); diff --git a/langtools/test/tools/javac/6508981/p/A.java b/langtools/test/tools/javac/6508981/p/A.java index 27b70509785..72b8da04a7a 100644 --- a/langtools/test/tools/javac/6508981/p/A.java +++ b/langtools/test/tools/javac/6508981/p/A.java @@ -20,5 +20,6 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package p; class A { } diff --git a/langtools/test/tools/javac/6547131/T.java b/langtools/test/tools/javac/6547131/T.java index 6024d05875e..76d8a5b344f 100644 --- a/langtools/test/tools/javac/6547131/T.java +++ b/langtools/test/tools/javac/6547131/T.java @@ -2,7 +2,7 @@ * @test * @bug 6547131 * @summary java.lang.ClassFormatError when using old collection API - * @compile T.java + * @compile p/Outer.jasm p/Outer$I.jasm T.java * @run main T */ diff --git a/langtools/test/tools/javac/6547131/p/Outer$I.class b/langtools/test/tools/javac/6547131/p/Outer$I.class deleted file mode 100644 index 4528e79cc58..00000000000 Binary files a/langtools/test/tools/javac/6547131/p/Outer$I.class and /dev/null differ diff --git a/langtools/test/tools/javac/6547131/p/Outer.class b/langtools/test/tools/javac/6547131/p/Outer.class deleted file mode 100644 index 9ef1a235444..00000000000 Binary files a/langtools/test/tools/javac/6547131/p/Outer.class and /dev/null differ diff --git a/langtools/test/tools/javac/6917288/GraphicalInstallerTest.java b/langtools/test/tools/javac/6917288/GraphicalInstallerTest.java index 9c49bb56940..f976bd97189 100644 --- a/langtools/test/tools/javac/6917288/GraphicalInstallerTest.java +++ b/langtools/test/tools/javac/6917288/GraphicalInstallerTest.java @@ -21,7 +21,6 @@ * questions. */ - /* @test * @bug 6917288 * @summary Unnamed nested class is not generated diff --git a/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedA.java b/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedA.java index 1a92fcf5b1d..67dc6f555fb 100644 --- a/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedA.java +++ b/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedA.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg; public class ClassToBeStaticallyImportedA { diff --git a/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedB.java b/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedB.java index b3ceaf7360e..5aabbeed0a7 100644 --- a/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedB.java +++ b/langtools/test/tools/javac/7153958/pkg/ClassToBeStaticallyImportedB.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg; public class ClassToBeStaticallyImportedB { diff --git a/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.class b/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.class deleted file mode 100644 index 64979c9bb76..00000000000 Binary files a/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.class and /dev/null differ diff --git a/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.jasm b/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.jasm new file mode 100644 index 00000000000..ea4d49e8ef9 --- /dev/null +++ b/langtools/test/tools/javac/InnerClassesAttribute/Outside$1$Inside.jasm @@ -0,0 +1,38 @@ +/* + * 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. + * + * 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. + */ + +super class Outside$1$Inside + version 45:3 +{ + +Method "":"()V" + stack 1 locals 1 +{ + aload_0; + invokespecial Method java/lang/Object."":"()V"; + return; +} + +private InnerClass Inside=class Outside$1$Inside; + +} \ No newline at end of file diff --git a/langtools/test/tools/javac/InnerClassesAttribute/Outside.class b/langtools/test/tools/javac/InnerClassesAttribute/Outside.class deleted file mode 100644 index 4bd637eaa2c..00000000000 Binary files a/langtools/test/tools/javac/InnerClassesAttribute/Outside.class and /dev/null differ diff --git a/langtools/test/tools/javac/InnerClassesAttribute/Outside.jasm b/langtools/test/tools/javac/InnerClassesAttribute/Outside.jasm new file mode 100644 index 00000000000..29478601ed3 --- /dev/null +++ b/langtools/test/tools/javac/InnerClassesAttribute/Outside.jasm @@ -0,0 +1,44 @@ +/* + * 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. + * + * 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. + */ + +super public class Outside + version 45:3 +{ + +public Method "":"()V" + stack 1 locals 1 +{ + aload_0; + invokespecial Method java/lang/Object."":"()V"; + return; +} + +Method method:"()V" + stack 0 locals 1 +{ + return; +} + +private InnerClass Inside=class Outside$1$Inside; + +} \ No newline at end of file diff --git a/langtools/test/tools/javac/InnerClassesAttribute/Test.java b/langtools/test/tools/javac/InnerClassesAttribute/Test.java index 7ecbc752863..f2357ada27c 100644 --- a/langtools/test/tools/javac/InnerClassesAttribute/Test.java +++ b/langtools/test/tools/javac/InnerClassesAttribute/Test.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 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 @@ -27,7 +27,7 @@ * @summary The compiler used to crash when it saw a correctly-formed * InnerClasses attribute in a .class file. * @author turnidge - * + * @build Outside Outside$1$Inside * @compile Test.java */ public diff --git a/langtools/test/tools/javac/MethodParameters/ClassFileVisitor.java b/langtools/test/tools/javac/MethodParameters/ClassFileVisitor.java index 1e12cb82e72..8640e18cc3f 100644 --- a/langtools/test/tools/javac/MethodParameters/ClassFileVisitor.java +++ b/langtools/test/tools/javac/MethodParameters/ClassFileVisitor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 @@ -279,7 +279,7 @@ class ClassFileVisitor extends Tester.Visitor { userParam = param; } } - if (expect != null && !param.equals(expect)) { + if (check > 0 && expect != null && !param.equals(expect)) { error(prefix + "param[" + x + "]='" + param + "' expected '" + expect + "'"); return null; @@ -346,6 +346,17 @@ class ClassFileVisitor extends Tester.Visitor { } } } + + if (synthetic && !mandated && !allowSynthetic) { + //patch treatment for local captures + if (isAnon || (isInner & !isStatic)) { + expect = "val\\$.*"; + allowSynthetic = true; + if (isFinal) { + expect = "final val\\$.*"; + } + } + } } else if (isEnum && mNumParams == 1 && index == 0 && mName.equals("valueOf")) { expect = "name"; allowMandated = true; @@ -411,7 +422,6 @@ class ClassFileVisitor extends Tester.Visitor { if (mSynthetic) { return 0; } - // Otherwise, do check test parameter naming convention. return 1; } diff --git a/langtools/test/tools/javac/MethodParameters/LocalClassTest.java b/langtools/test/tools/javac/MethodParameters/LocalClassTest.java index f3468a951c9..9d71e19bd71 100644 --- a/langtools/test/tools/javac/MethodParameters/LocalClassTest.java +++ b/langtools/test/tools/javac/MethodParameters/LocalClassTest.java @@ -45,6 +45,16 @@ class LocalClassTest { } new LocalClassTest().foo(); } + + void test(final int i) { + class CapturingLocal { + CapturingLocal(final int j) { + this(new Object() { void test() { int x = i; } }); + } + CapturingLocal(Object o) { } + } + new CapturingLocal(i) { }; + } } diff --git a/langtools/test/tools/javac/MethodParameters/LocalClassTest.out b/langtools/test/tools/javac/MethodParameters/LocalClassTest.out index 24eda916fb1..bd25ff3a6be 100644 --- a/langtools/test/tools/javac/MethodParameters/LocalClassTest.out +++ b/langtools/test/tools/javac/MethodParameters/LocalClassTest.out @@ -1,12 +1,21 @@ -class LocalClassTest$1Local_has_constructor -- inner -LocalClassTest$1Local_has_constructor.(final this$0/*implicit*/, a, ba) -LocalClassTest$1Local_has_constructor.(final this$0/*implicit*/) -LocalClassTest$1Local_has_constructor.foo(m, nm) -LocalClassTest$1Local_has_constructor.foo() +class LocalClassTest$1 -- anon +LocalClassTest$1.(final this$0/*implicit*/, final j, final val$i/*synthetic*/) +class LocalClassTest$1CapturingLocal$1 -- anon +LocalClassTest$1CapturingLocal$1.(final val$this$0/*synthetic*/, final val$val$i/*synthetic*/) +LocalClassTest$1CapturingLocal$1.test() +class LocalClassTest$1CapturingLocal -- inner +LocalClassTest$1CapturingLocal.(final this$0/*implicit*/, final j, final val$i/*synthetic*/) +LocalClassTest$1CapturingLocal.(final this$0/*implicit*/, o, final val$i/*synthetic*/) class LocalClassTest$1Local_default_constructor -- inner LocalClassTest$1Local_default_constructor.(final this$0/*implicit*/) LocalClassTest$1Local_default_constructor.foo() LocalClassTest$1Local_default_constructor.foo(m, nm) +class LocalClassTest$1Local_has_constructor -- inner +LocalClassTest$1Local_has_constructor.(final this$0/*implicit*/) +LocalClassTest$1Local_has_constructor.(final this$0/*implicit*/, a, ba) +LocalClassTest$1Local_has_constructor.foo() +LocalClassTest$1Local_has_constructor.foo(m, nm) class LocalClassTest -- LocalClassTest.() -LocalClassTest.foo() \ No newline at end of file +LocalClassTest.foo() +LocalClassTest.test(final i) diff --git a/langtools/test/tools/javac/MethodParameters/ReflectionVisitor.java b/langtools/test/tools/javac/MethodParameters/ReflectionVisitor.java index 8979f20dfa8..f98b6b4138b 100644 --- a/langtools/test/tools/javac/MethodParameters/ReflectionVisitor.java +++ b/langtools/test/tools/javac/MethodParameters/ReflectionVisitor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 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 @@ -164,6 +164,17 @@ public class ReflectionVisitor extends Tester.Visitor { } } + if (p.isSynthetic() && !p.isImplicit() && !allowSynthetic) { + //patch treatment for local captures + if (isAnon || ((isLocal || isAnon) & !isStatic)) { + expect = "val\\$.*"; + allowSynthetic = true; + if (isFinal) { + expect = "final val\\$.*"; + } + } + } + // Check expected flags if (p.isSynthetic() && p.isImplicit()) { error(prefix + "param[" + i + "]='" + pname + diff --git a/langtools/test/tools/javac/NameClash/NameClashTest.java b/langtools/test/tools/javac/NameClash/NameClashTest.java index c3e9506e567..4697048a7b4 100644 --- a/langtools/test/tools/javac/NameClash/NameClashTest.java +++ b/langtools/test/tools/javac/NameClash/NameClashTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Oracle and/or its affiliates. All rights reserved. + * 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 diff --git a/langtools/test/tools/javac/T6435291/T.class b/langtools/test/tools/javac/T6435291/T.class deleted file mode 100644 index 7875a40e32b..00000000000 Binary files a/langtools/test/tools/javac/T6435291/T.class and /dev/null differ diff --git a/langtools/test/tools/javac/T6435291/T6435291.java b/langtools/test/tools/javac/T6435291/T6435291.java index 2ac0355d69f..ace80aa81c5 100644 --- a/langtools/test/tools/javac/T6435291/T6435291.java +++ b/langtools/test/tools/javac/T6435291/T6435291.java @@ -30,6 +30,7 @@ * jdk.compiler/com.sun.tools.javac.code * jdk.compiler/com.sun.tools.javac.main * jdk.compiler/com.sun.tools.javac.util + * @build T * @run main/othervm T6435291 */ diff --git a/langtools/test/tools/javac/T6458823/MyProcessor.java b/langtools/test/tools/javac/T6458823/MyProcessor.java index 43e96b131cc..17a929aedb0 100644 --- a/langtools/test/tools/javac/T6458823/MyProcessor.java +++ b/langtools/test/tools/javac/T6458823/MyProcessor.java @@ -1,25 +1,25 @@ - /* - * Copyright (c) 2010, 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. - */ +/* + * Copyright (c) 2010, 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. + */ import java.util.Set; import javax.annotation.processing.*; diff --git a/langtools/test/tools/javac/T6942649.java b/langtools/test/tools/javac/T6942649.java index 8d7916e0640..49502ae2bab 100644 --- a/langtools/test/tools/javac/T6942649.java +++ b/langtools/test/tools/javac/T6942649.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 6942649 diff --git a/langtools/test/tools/javac/annotations/neg/8022765/VerifyAnnotationsAttributed.java b/langtools/test/tools/javac/annotations/neg/8022765/VerifyAnnotationsAttributed.java index 8d67b25503f..3c56cedd00e 100644 --- a/langtools/test/tools/javac/annotations/neg/8022765/VerifyAnnotationsAttributed.java +++ b/langtools/test/tools/javac/annotations/neg/8022765/VerifyAnnotationsAttributed.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import com.sun.source.tree.CompilationUnitTree; import com.sun.source.tree.IdentifierTree; import com.sun.source.tree.MemberSelectTree; diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/TargetTypes.java b/langtools/test/tools/javac/annotations/typeAnnotations/TargetTypes.java index 2d42a640ae5..d36ee7cf237 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/TargetTypes.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/TargetTypes.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.*; import static java.lang.annotation.ElementType.*; import static java.lang.annotation.RetentionPolicy.*; diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/TypeProcOnly.java b/langtools/test/tools/javac/annotations/typeAnnotations/TypeProcOnly.java index 98d49baea5d..5ab5a76ba47 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/TypeProcOnly.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/TypeProcOnly.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.io.*; import java.util.Set; import java.util.HashSet; diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/classfile/T8008769.java b/langtools/test/tools/javac/annotations/typeAnnotations/classfile/T8008769.java index 5eacedf7512..d5598cdb593 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/classfile/T8008769.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/classfile/T8008769.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + /* * @test * @summary Repeated type-annotations on type parm of local variable diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/PackageProcessor.java b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/PackageProcessor.java index 3983e1f3a1c..00025e32795 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/PackageProcessor.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/PackageProcessor.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.util.HashSet; import java.util.Set; diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/Anno.java b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/Anno.java index 396b9c40360..f5b0f0c5b56 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/Anno.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/Anno.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package mypackage; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Retention; diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/MyClass.java b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/MyClass.java index b83b1aa47cf..e2d9c5630ba 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/MyClass.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/packageanno/mypackage/MyClass.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package mypackage; public class MyClass {} diff --git a/langtools/test/tools/javac/api/6557752/T6557752.java b/langtools/test/tools/javac/api/6557752/T6557752.java index 34e9a38075b..1db1c608802 100644 --- a/langtools/test/tools/javac/api/6557752/T6557752.java +++ b/langtools/test/tools/javac/api/6557752/T6557752.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 6557752 diff --git a/langtools/test/tools/javac/api/TestGetElementReferenceData.java b/langtools/test/tools/javac/api/TestGetElementReferenceData.java index a72d95ff816..8f2b376aae6 100644 --- a/langtools/test/tools/javac/api/TestGetElementReferenceData.java +++ b/langtools/test/tools/javac/api/TestGetElementReferenceData.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package test; /*getElement:PACKAGE:test*/ import java.lang.annotation.*; diff --git a/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerClassesTest.java b/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerClassesTest.java index f9f577fc3e1..d362fcff2dc 100644 --- a/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerClassesTest.java +++ b/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerClassesTest.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 8034854 8042251 diff --git a/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerEnumInInnerAnnotationTest.java b/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerEnumInInnerAnnotationTest.java index 85467276cc1..25d8fe391a7 100644 --- a/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerEnumInInnerAnnotationTest.java +++ b/langtools/test/tools/javac/classfiles/attributes/innerclasses/InnerEnumInInnerAnnotationTest.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 8042251 diff --git a/langtools/test/tools/javac/defaultMethods/Assertions.java b/langtools/test/tools/javac/defaultMethods/Assertions.java index 46a09a93417..7d86c6f0572 100644 --- a/langtools/test/tools/javac/defaultMethods/Assertions.java +++ b/langtools/test/tools/javac/defaultMethods/Assertions.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package test; import java.util.Arrays; diff --git a/langtools/test/tools/javac/defaultMethods/crossCompile/Clinit.java b/langtools/test/tools/javac/defaultMethods/crossCompile/Clinit.java index 60dc4f44edb..e11891b2b46 100644 --- a/langtools/test/tools/javac/defaultMethods/crossCompile/Clinit.java +++ b/langtools/test/tools/javac/defaultMethods/crossCompile/Clinit.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + interface Clinit { String s = Inner.m(); diff --git a/langtools/test/tools/javac/diags/HTMLWriter.java b/langtools/test/tools/javac/diags/HTMLWriter.java index 1734d611a7c..e6f4c1d6a43 100644 --- a/langtools/test/tools/javac/diags/HTMLWriter.java +++ b/langtools/test/tools/javac/diags/HTMLWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996,2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2010, 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 @@ -21,8 +21,6 @@ * questions. */ - - import java.io.BufferedWriter; import java.io.File; import java.io.IOException; diff --git a/langtools/test/tools/javac/diags/examples/DiamondAndAnonClass.java b/langtools/test/tools/javac/diags/examples/DiamondAndAnonClass.java index 8e94de00630..10093afc87e 100644 --- a/langtools/test/tools/javac/diags/examples/DiamondAndAnonClass.java +++ b/langtools/test/tools/javac/diags/examples/DiamondAndAnonClass.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 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 diff --git a/langtools/test/tools/javac/diags/examples/DiamondAndNonDenotableTypes.java b/langtools/test/tools/javac/diags/examples/DiamondAndNonDenotableTypes.java index 0f2650d3e47..70ed0323857 100644 --- a/langtools/test/tools/javac/diags/examples/DiamondAndNonDenotableTypes.java +++ b/langtools/test/tools/javac/diags/examples/DiamondAndNonDenotableTypes.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Oracle and/or its affiliates. All rights reserved. + * 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 diff --git a/langtools/test/tools/javac/doctree/positions/TestPositionSource.java b/langtools/test/tools/javac/doctree/positions/TestPositionSource.java index 801af3d687c..162c10afd7e 100644 --- a/langtools/test/tools/javac/doctree/positions/TestPositionSource.java +++ b/langtools/test/tools/javac/doctree/positions/TestPositionSource.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + public class TestPositionSource { /**First sentence. diff --git a/langtools/test/tools/javac/file/zip/8003512/LoadClassFromJava6CreatedJarTest.java b/langtools/test/tools/javac/file/zip/8003512/LoadClassFromJava6CreatedJarTest.java index c2a3426ba1d..f6f53c2c0e8 100644 --- a/langtools/test/tools/javac/file/zip/8003512/LoadClassFromJava6CreatedJarTest.java +++ b/langtools/test/tools/javac/file/zip/8003512/LoadClassFromJava6CreatedJarTest.java @@ -1,4 +1,3 @@ - /* * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. @@ -22,6 +21,7 @@ * questions. */ + /* * @test * @bug 8003512 diff --git a/langtools/test/tools/javac/flow/AliveRanges.java b/langtools/test/tools/javac/flow/AliveRanges.java index 2494f77aca8..d1d601a637c 100644 --- a/langtools/test/tools/javac/flow/AliveRanges.java +++ b/langtools/test/tools/javac/flow/AliveRanges.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.*; @Repeatable(AliveRanges.class) diff --git a/langtools/test/tools/javac/generics/8004094/B.java b/langtools/test/tools/javac/generics/8004094/B.java index 735a7fdfa85..03654508c37 100644 --- a/langtools/test/tools/javac/generics/8004094/B.java +++ b/langtools/test/tools/javac/generics/8004094/B.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + abstract class A { private static String s = null; diff --git a/langtools/test/tools/javac/generics/bridges/Bridge.java b/langtools/test/tools/javac/generics/bridges/Bridge.java index 76e323eeadc..545e530a496 100644 --- a/langtools/test/tools/javac/generics/bridges/Bridge.java +++ b/langtools/test/tools/javac/generics/bridges/Bridge.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.Repeatable; @Repeatable(Bridges.class) diff --git a/langtools/test/tools/javac/generics/bridges/Bridges.java b/langtools/test/tools/javac/generics/bridges/Bridges.java index 1980cf19a0b..a1a117aab69 100644 --- a/langtools/test/tools/javac/generics/bridges/Bridges.java +++ b/langtools/test/tools/javac/generics/bridges/Bridges.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + @interface Bridges { Bridge[] value(); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestBridgeWithDefault.java b/langtools/test/tools/javac/generics/bridges/tests/TestBridgeWithDefault.java index 51a7ada9624..98fb822d8c3 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestBridgeWithDefault.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestBridgeWithDefault.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestBridgeWithDefault { interface A { Object m(int x); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical01.java b/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical01.java index 370cddc54e3..6b914ff00a2 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical01.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical01.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestClassAndInterfaceBridgeIdentical01 { interface A { Object m(); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical02.java b/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical02.java index c774d609d35..986f2cff44c 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical02.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestClassAndInterfaceBridgeIdentical02.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestClassAndInterfaceBridgeIdentical02 { interface A { void m(X x); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestNoBridgeInSiblingsSuper.java b/langtools/test/tools/javac/generics/bridges/tests/TestNoBridgeInSiblingsSuper.java index bfe1dcb5367..b83f14ee969 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestNoBridgeInSiblingsSuper.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestNoBridgeInSiblingsSuper.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestNoBridgeInSiblingSuper { interface A { Object m(); } interface B { String m(); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges01.java b/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges01.java index d575ef9d8c3..f8824ab5003 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges01.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges01.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestNoDuplicateBridges01 { interface A1 { Object m(); } interface A2 { Object m(); } diff --git a/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges02.java b/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges02.java index adab090ac9e..d19d5d3e907 100644 --- a/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges02.java +++ b/langtools/test/tools/javac/generics/bridges/tests/TestNoDuplicateBridges02.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class TestNoDuplicateBridges02 { interface A { A get(); diff --git a/langtools/test/tools/javac/generics/diamond/pos/NestedDiamondAllocationTest.java b/langtools/test/tools/javac/generics/diamond/pos/NestedDiamondAllocationTest.java index 7805e58b39b..e442c32a87f 100644 --- a/langtools/test/tools/javac/generics/diamond/pos/NestedDiamondAllocationTest.java +++ b/langtools/test/tools/javac/generics/diamond/pos/NestedDiamondAllocationTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Oracle and/or its affiliates. All rights reserved. + * 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 diff --git a/langtools/test/tools/javac/generics/inference/CaptureInDeclaredBound.java b/langtools/test/tools/javac/generics/inference/CaptureInDeclaredBound.java new file mode 100644 index 00000000000..6d5744afb76 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/CaptureInDeclaredBound.java @@ -0,0 +1,45 @@ +/* + * 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. + * + * 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 7190296 8033718 + * @summary F-bounded capture variable is within its declared bound + * @compile CaptureInDeclaredBound.java + */ + +public class CaptureInDeclaredBound { + + class C {} + + interface I> { + C get(); + } + + > void m(C arg) {} + + void test(I arg) { + m(arg.get()); + } + +} diff --git a/langtools/test/tools/javac/implicitCompile/Implicit.java b/langtools/test/tools/javac/implicitCompile/Implicit.java index 4a36d896ffa..07f802ed778 100644 --- a/langtools/test/tools/javac/implicitCompile/Implicit.java +++ b/langtools/test/tools/javac/implicitCompile/Implicit.java @@ -20,5 +20,6 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + class Implicit { } diff --git a/langtools/test/tools/javac/importscope/TestDuplicateImport.java b/langtools/test/tools/javac/importscope/TestDuplicateImport.java index 9922e7601fc..7b467697c07 100644 --- a/langtools/test/tools/javac/importscope/TestDuplicateImport.java +++ b/langtools/test/tools/javac/importscope/TestDuplicateImport.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011-2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 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 diff --git a/langtools/test/tools/javac/importscope/TestLazyImportScope.java b/langtools/test/tools/javac/importscope/TestLazyImportScope.java index 033e5a6a2a4..67f8fe63809 100644 --- a/langtools/test/tools/javac/importscope/TestLazyImportScope.java +++ b/langtools/test/tools/javac/importscope/TestLazyImportScope.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011-2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 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 diff --git a/langtools/test/tools/javac/lambda/8068399/T8068399.java b/langtools/test/tools/javac/lambda/8068399/T8068399.java index 7df8a70724c..f78236cd373 100644 --- a/langtools/test/tools/javac/lambda/8068399/T8068399.java +++ b/langtools/test/tools/javac/lambda/8068399/T8068399.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + /* * @test * @bug 8068399 8069545 diff --git a/langtools/test/tools/javac/lambda/8142876/T8142876.java b/langtools/test/tools/javac/lambda/8142876/T8142876.java new file mode 100644 index 00000000000..e5c99c12795 --- /dev/null +++ b/langtools/test/tools/javac/lambda/8142876/T8142876.java @@ -0,0 +1,45 @@ +/* + * 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. + */ + +/* + * @test + * @bug 8142876 + * @summary Javac does not correctly implement wildcards removal from functional interfaces + * @compile T8142876.java + */ +class T8142876 { + interface I { + void m(); + } + + void test() { + I succeed = this::ff; + I, String> failed = this::ff; + } + + interface O {} + + private void ff(){} +} diff --git a/langtools/test/tools/javac/lambda/LocalBreakAndContinue.java b/langtools/test/tools/javac/lambda/LocalBreakAndContinue.java index 16505b4fcd6..6a2066a2a38 100644 --- a/langtools/test/tools/javac/lambda/LocalBreakAndContinue.java +++ b/langtools/test/tools/javac/lambda/LocalBreakAndContinue.java @@ -19,7 +19,6 @@ * 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. - */ /* diff --git a/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodTestCase.java b/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodTestCase.java index 964a59658b1..ebee731c187 100644 --- a/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodTestCase.java +++ b/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodTestCase.java @@ -19,8 +19,8 @@ * 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. - * */ + import java.io.File; import java.io.IOException; import java.lang.reflect.Method; diff --git a/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodsTemplateTest.java b/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodsTemplateTest.java index 028602ea057..9d6913edf5f 100644 --- a/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodsTemplateTest.java +++ b/langtools/test/tools/javac/lambda/bridge/template_tests/BridgeMethodsTemplateTest.java @@ -19,8 +19,8 @@ * 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. - * */ + import java.io.IOException; import org.testng.annotations.Test; diff --git a/langtools/test/tools/javac/lambda/inaccessibleMref01/p1/C.java b/langtools/test/tools/javac/lambda/inaccessibleMref01/p1/C.java index be4f563f70c..6c3410cedd3 100644 --- a/langtools/test/tools/javac/lambda/inaccessibleMref01/p1/C.java +++ b/langtools/test/tools/javac/lambda/inaccessibleMref01/p1/C.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package p1; public class C { diff --git a/langtools/test/tools/javac/lambda/inaccessibleMref02/p1/C.java b/langtools/test/tools/javac/lambda/inaccessibleMref02/p1/C.java index b97ad24c5c4..fcf231583d9 100644 --- a/langtools/test/tools/javac/lambda/inaccessibleMref02/p1/C.java +++ b/langtools/test/tools/javac/lambda/inaccessibleMref02/p1/C.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package p1; class Sup { diff --git a/langtools/test/tools/javac/lambda/methodReferenceExecution/pkg/B.java b/langtools/test/tools/javac/lambda/methodReferenceExecution/pkg/B.java index 3233caae9e5..8b474e443e0 100644 --- a/langtools/test/tools/javac/lambda/methodReferenceExecution/pkg/B.java +++ b/langtools/test/tools/javac/lambda/methodReferenceExecution/pkg/B.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg; class A { public static void m() { diff --git a/langtools/test/tools/javac/lambda/separate/Foo.java b/langtools/test/tools/javac/lambda/separate/Foo.java index 506f532d5ca..bb60c7b8df9 100644 --- a/langtools/test/tools/javac/lambda/separate/Foo.java +++ b/langtools/test/tools/javac/lambda/separate/Foo.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + interface Foo { void m(X x); } diff --git a/langtools/test/tools/javac/missingSuperRecovery/MissingSuperRecovery.java b/langtools/test/tools/javac/missingSuperRecovery/MissingSuperRecovery.java index 9f622a02c7c..8ec680dd9bd 100644 --- a/langtools/test/tools/javac/missingSuperRecovery/MissingSuperRecovery.java +++ b/langtools/test/tools/javac/missingSuperRecovery/MissingSuperRecovery.java @@ -4,7 +4,7 @@ * @summary Check for proper error recovery when superclass of extended * class is no longer available during a subsequent compilation. * @author maddox - * + * @build impl * @compile/fail/ref=MissingSuperRecovery.out -XDdiags=%b:%l:%_%m MissingSuperRecovery.java */ diff --git a/langtools/test/tools/javac/missingSuperRecovery/impl.class b/langtools/test/tools/javac/missingSuperRecovery/impl.class deleted file mode 100644 index 670d4baaf30..00000000000 Binary files a/langtools/test/tools/javac/missingSuperRecovery/impl.class and /dev/null differ diff --git a/langtools/test/tools/javac/missingSuperRecovery/impl.jasm b/langtools/test/tools/javac/missingSuperRecovery/impl.jasm new file mode 100644 index 00000000000..331ad863dc1 --- /dev/null +++ b/langtools/test/tools/javac/missingSuperRecovery/impl.jasm @@ -0,0 +1,43 @@ +/* + * 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. + * + * 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. + */ + +super public class impl + implements base + version 45:3 +{ + +public Method "":"()V" + stack 1 locals 1 +{ + aload_0; + invokespecial Method java/lang/Object."":"()V"; + return; +} + +public Method run:"()V" + stack 0 locals 1 +{ + return; +} + +} \ No newline at end of file diff --git a/langtools/test/tools/javac/options/T7022337.java b/langtools/test/tools/javac/options/T7022337.java index b3bb0ba6ff9..450a623edc3 100644 --- a/langtools/test/tools/javac/options/T7022337.java +++ b/langtools/test/tools/javac/options/T7022337.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 7022337 diff --git a/langtools/test/tools/javac/policy/test3/Test.java b/langtools/test/tools/javac/policy/test3/Test.java index 3fce702437d..9341843db7e 100644 --- a/langtools/test/tools/javac/policy/test3/Test.java +++ b/langtools/test/tools/javac/policy/test3/Test.java @@ -21,7 +21,6 @@ * questions. */ - /* @test * @bug 6813059 * @summary diff --git a/langtools/test/tools/javac/processing/6414633/A.java b/langtools/test/tools/javac/processing/6414633/A.java index 13754d09cbe..b0a463bb184 100644 --- a/langtools/test/tools/javac/processing/6414633/A.java +++ b/langtools/test/tools/javac/processing/6414633/A.java @@ -21,7 +21,6 @@ * questions. */ - import java.util.*; import javax.annotation.*; import javax.annotation.processing.*; diff --git a/langtools/test/tools/javac/processing/TestWarnErrorCount.java b/langtools/test/tools/javac/processing/TestWarnErrorCount.java index c20839745ee..6d1d33c9e59 100644 --- a/langtools/test/tools/javac/processing/TestWarnErrorCount.java +++ b/langtools/test/tools/javac/processing/TestWarnErrorCount.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 7022337 diff --git a/langtools/test/tools/javac/processing/model/element/TestMissingElement/TestMissingElement.java b/langtools/test/tools/javac/processing/model/element/TestMissingElement/TestMissingElement.java index 03e23acd16f..fb71747522f 100644 --- a/langtools/test/tools/javac/processing/model/element/TestMissingElement/TestMissingElement.java +++ b/langtools/test/tools/javac/processing/model/element/TestMissingElement/TestMissingElement.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 6639645 7026414 7025809 diff --git a/langtools/test/tools/javac/resolve/Candidate.java b/langtools/test/tools/javac/resolve/Candidate.java index a36208b56fa..dfc8826d766 100644 --- a/langtools/test/tools/javac/resolve/Candidate.java +++ b/langtools/test/tools/javac/resolve/Candidate.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.ElementType; import java.lang.annotation.Target; diff --git a/langtools/test/tools/javac/resolve/Pos.java b/langtools/test/tools/javac/resolve/Pos.java index 8af315fcfa3..1f5d8a97942 100644 --- a/langtools/test/tools/javac/resolve/Pos.java +++ b/langtools/test/tools/javac/resolve/Pos.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.ElementType; import java.lang.annotation.Target; diff --git a/langtools/test/tools/javac/resolve/TraceResolve.java b/langtools/test/tools/javac/resolve/TraceResolve.java index ddc83996e80..db3bf0a2ec0 100644 --- a/langtools/test/tools/javac/resolve/TraceResolve.java +++ b/langtools/test/tools/javac/resolve/TraceResolve.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.lang.annotation.ElementType; import java.lang.annotation.Target; diff --git a/langtools/test/tools/javac/resolve/tests/AbstractMerge.java b/langtools/test/tools/javac/resolve/tests/AbstractMerge.java index e6feb08949b..2e28dc7c753 100644 --- a/langtools/test/tools/javac/resolve/tests/AbstractMerge.java +++ b/langtools/test/tools/javac/resolve/tests/AbstractMerge.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + @TraceResolve class AbstractMerge { diff --git a/langtools/test/tools/javac/scope/DupUnsharedTest.java b/langtools/test/tools/javac/scope/DupUnsharedTest.java index 8f9180597a0..673536553e6 100644 --- a/langtools/test/tools/javac/scope/DupUnsharedTest.java +++ b/langtools/test/tools/javac/scope/DupUnsharedTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 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 diff --git a/langtools/test/tools/javac/scope/RemoveSymbolUnitTest.java b/langtools/test/tools/javac/scope/RemoveSymbolUnitTest.java index cf21521bc2e..1b9628a4d86 100644 --- a/langtools/test/tools/javac/scope/RemoveSymbolUnitTest.java +++ b/langtools/test/tools/javac/scope/RemoveSymbolUnitTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Oracle and/or its affiliates. All rights reserved. + * 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 diff --git a/langtools/test/tools/javac/staticImport/6665223/pkg/A.java b/langtools/test/tools/javac/staticImport/6665223/pkg/A.java index 4bd6462326b..0c94f1ed872 100644 --- a/langtools/test/tools/javac/staticImport/6665223/pkg/A.java +++ b/langtools/test/tools/javac/staticImport/6665223/pkg/A.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg; import static pkg.B.b; diff --git a/langtools/test/tools/javac/staticImport/6665223/pkg/B.java b/langtools/test/tools/javac/staticImport/6665223/pkg/B.java index ce3c4a84eb4..261018b744e 100644 --- a/langtools/test/tools/javac/staticImport/6665223/pkg/B.java +++ b/langtools/test/tools/javac/staticImport/6665223/pkg/B.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package pkg; class B extends B2 {} diff --git a/langtools/test/tools/javac/tree/JavacTreeScannerTest.java b/langtools/test/tools/javac/tree/JavacTreeScannerTest.java index dc39a68b02d..e2b7676add3 100644 --- a/langtools/test/tools/javac/tree/JavacTreeScannerTest.java +++ b/langtools/test/tools/javac/tree/JavacTreeScannerTest.java @@ -21,7 +21,6 @@ * questions. */ - /** * Utility and test program to check javac's internal TreeScanner class. * The program can be run standalone, or as a jtreg test. For info on diff --git a/langtools/test/tools/javac/tree/SourceTreeScannerTest.java b/langtools/test/tools/javac/tree/SourceTreeScannerTest.java index c7ea50594b0..5882037e1f6 100644 --- a/langtools/test/tools/javac/tree/SourceTreeScannerTest.java +++ b/langtools/test/tools/javac/tree/SourceTreeScannerTest.java @@ -21,7 +21,6 @@ * questions. */ - /** * Utility and test program to check javac's internal TreeScanner class. * The program can be run standalone, or as a jtreg test. For info on diff --git a/langtools/test/tools/javac/tree/TestAnnotatedAnonClass.java b/langtools/test/tools/javac/tree/TestAnnotatedAnonClass.java index a1864260447..25b0b689f43 100644 --- a/langtools/test/tools/javac/tree/TestAnnotatedAnonClass.java +++ b/langtools/test/tools/javac/tree/TestAnnotatedAnonClass.java @@ -21,7 +21,6 @@ * questions. */ - /* * This file is not a regular test, but is processed by ./TreePosTest.java, * which verifies the position info in the javac tree. diff --git a/langtools/test/tools/javac/types/CastTest.java b/langtools/test/tools/javac/types/CastTest.java index 3d6d3f7c5cf..6c94cd7a2c6 100644 --- a/langtools/test/tools/javac/types/CastTest.java +++ b/langtools/test/tools/javac/types/CastTest.java @@ -35,8 +35,6 @@ */ import com.sun.tools.javac.code.Type; -import com.sun.tools.javac.code.Type.*; -import com.sun.tools.javac.code.Symbol.*; import java.lang.reflect.Array; import static com.sun.tools.javac.code.Flags.*; @@ -65,7 +63,7 @@ public class CastTest extends TypeHarness { /*C*/ { F , F , F , F , F , F , F , F , T, F , T, T, F , F , F , F , F , F , F , F , F , F , F , F }, /*+C*/ { F , F , F , F , F , F , F , F , F, T , F, T, F , F , F , F , F , F , F , F , F , F , F , F }, /*I*/ { F , F , F , F , F , F , F , F , T, F , T, T, F , F , F , F , F , F , F , F , F , F , F , F }, - /*T*/ { F , F , F , F , F , F , F , F , T, T , T, T, T , T , T , T , T , T , T , T , T , T , T , T }, + /*T*/ { T , T , T , T , T , T , T , T , T, T , T, T, T , T , T , T , T , T , T , T , T , T , T , T }, /*byte[]*/ { F , F , F , F , F , F , F , F , F, F , F, T, T , F , F , F , F , F , F , F , F , F , F , F }, /*short[]*/ { F , F , F , F , F , F , F , F , F, F , F, T, F , T , F , F , F , F , F , F , F , F , F , F }, /*int[]*/ { F , F , F , F , F , F , F , F , F, F , F, T, F , F , T , F , F , F , F , F , F , F , F , F }, diff --git a/langtools/test/tools/javac/types/CastToTypeVarTest.java b/langtools/test/tools/javac/types/CastToTypeVarTest.java new file mode 100644 index 00000000000..27ea6ea7dd3 --- /dev/null +++ b/langtools/test/tools/javac/types/CastToTypeVarTest.java @@ -0,0 +1,35 @@ +/* + * 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. + * + * 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 8144832 + * @summary cast conversion fails when converting a type-variable to primitive type + * @compile -Werror -Xlint:all CastToTypeVarTest.java + */ + +public class CastToTypeVarTest { + void foo(Y y) { + X x = (X)y; + } +} diff --git a/langtools/test/tools/javac/types/CastTypeVarToPrimitiveTest.java b/langtools/test/tools/javac/types/CastTypeVarToPrimitiveTest.java new file mode 100644 index 00000000000..5785c0ee117 --- /dev/null +++ b/langtools/test/tools/javac/types/CastTypeVarToPrimitiveTest.java @@ -0,0 +1,35 @@ +/* + * 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. + * + * 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 8144832 + * @summary cast conversion fails when converting a type-variable to primitive type + * @compile CastTypeVarToPrimitiveTest.java + */ + +public class CastTypeVarToPrimitiveTest { + void foo(T valIn){ + double val = (double)valIn; + } +} diff --git a/langtools/test/tools/javac/warnings/suppress/T8021112a.java b/langtools/test/tools/javac/warnings/suppress/T8021112a.java index 4e8b69895fa..6bd39c65a20 100644 --- a/langtools/test/tools/javac/warnings/suppress/T8021112a.java +++ b/langtools/test/tools/javac/warnings/suppress/T8021112a.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package test; /** diff --git a/langtools/test/tools/javadoc/parser/7091528/p/C3.java b/langtools/test/tools/javadoc/parser/7091528/p/C3.java index d363bccdb0d..4653b5a6ce0 100644 --- a/langtools/test/tools/javadoc/parser/7091528/p/C3.java +++ b/langtools/test/tools/javadoc/parser/7091528/p/C3.java @@ -21,7 +21,6 @@ * questions. */ - /** This is class C3, and no package for me please */ public class C3 {} diff --git a/langtools/test/tools/javadoc/subpackageIgnore/pkg1/not-subpkg/SomeJavaFile.java b/langtools/test/tools/javadoc/subpackageIgnore/pkg1/not-subpkg/SomeJavaFile.java index c50049c877e..7d886ce8861 100644 --- a/langtools/test/tools/javadoc/subpackageIgnore/pkg1/not-subpkg/SomeJavaFile.java +++ b/langtools/test/tools/javadoc/subpackageIgnore/pkg1/not-subpkg/SomeJavaFile.java @@ -20,3 +20,4 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + diff --git a/langtools/test/tools/javap/ExtPath.java b/langtools/test/tools/javap/ExtPath.java index f08409245c2..2ce3e5da128 100644 --- a/langtools/test/tools/javap/ExtPath.java +++ b/langtools/test/tools/javap/ExtPath.java @@ -21,7 +21,6 @@ * questions. */ - /** * @test * @bug 6428896 diff --git a/langtools/test/tools/javap/T4880672.java b/langtools/test/tools/javap/T4880672.java index fabacde9ade..922c1ae3b4a 100644 --- a/langtools/test/tools/javap/T4880672.java +++ b/langtools/test/tools/javap/T4880672.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 4880672 7031005 diff --git a/langtools/test/tools/javap/T6729471.java b/langtools/test/tools/javap/T6729471.java index 4f56cfcfc62..b54f8fe5167 100644 --- a/langtools/test/tools/javap/T6729471.java +++ b/langtools/test/tools/javap/T6729471.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 6729471 diff --git a/langtools/test/tools/javap/T6866657.java b/langtools/test/tools/javap/T6866657.java index c634e4b64b7..f9046fe346e 100644 --- a/langtools/test/tools/javap/T6866657.java +++ b/langtools/test/tools/javap/T6866657.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 6866657 diff --git a/langtools/test/tools/jdeps/VerboseFormat/JdepsDependencyClosure.java b/langtools/test/tools/jdeps/VerboseFormat/JdepsDependencyClosure.java index daddf15b1b1..fa6aeeacdbf 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/JdepsDependencyClosure.java +++ b/langtools/test/tools/jdeps/VerboseFormat/JdepsDependencyClosure.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + import java.io.IOException; import java.io.OutputStream; import java.io.PrintWriter; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/indirect/DontUseUnsafe2.java b/langtools/test/tools/jdeps/VerboseFormat/use/indirect/DontUseUnsafe2.java index 4a89a5cfb53..300a4a21a62 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/indirect/DontUseUnsafe2.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/indirect/DontUseUnsafe2.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.indirect; import use.unsafe.*; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/indirect/UseUnsafeIndirectly.java b/langtools/test/tools/jdeps/VerboseFormat/use/indirect/UseUnsafeIndirectly.java index add3363b5a7..70003e5d3ec 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/indirect/UseUnsafeIndirectly.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/indirect/UseUnsafeIndirectly.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.indirect; import use.unsafe.UseClassWithUnsafe; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/DontUseUnsafe3.java b/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/DontUseUnsafe3.java index b8dbe276b9e..979c994c859 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/DontUseUnsafe3.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/DontUseUnsafe3.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.indirect2; import use.unsafe.*; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/UseUnsafeIndirectly2.java b/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/UseUnsafeIndirectly2.java index df21bd5737f..2b8dc273c79 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/UseUnsafeIndirectly2.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/indirect2/UseUnsafeIndirectly2.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.indirect2; import use.unsafe.UseUnsafeClass; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/DontUseUnsafe.java b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/DontUseUnsafe.java index d3a65ef1b7d..fac1e7ea590 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/DontUseUnsafe.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/DontUseUnsafe.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.unsafe; public class DontUseUnsafe { diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass.java b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass.java index a57749acde4..2d8dc577e03 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.unsafe; import sun.misc.Unsafe; diff --git a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass2.java b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass2.java index fa4997768b9..21212228374 100644 --- a/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass2.java +++ b/langtools/test/tools/jdeps/VerboseFormat/use/unsafe/UseUnsafeClass2.java @@ -20,6 +20,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package use.unsafe; import sun.misc.Unsafe; diff --git a/langtools/test/tools/lib/ToolBox.java b/langtools/test/tools/lib/ToolBox.java index d77e84c26b7..4193f6f74a2 100644 --- a/langtools/test/tools/lib/ToolBox.java +++ b/langtools/test/tools/lib/ToolBox.java @@ -124,9 +124,6 @@ public class ToolBox { /** The stream used for logging output. */ public PrintStream out = System.err; - JavaCompiler compiler; - StandardJavaFileManager standardJavaFileManager; - /** * Checks if the host OS is some version of Windows. * @return true if the host OS is some version of Windows @@ -868,15 +865,18 @@ public class ToolBox { */ public class JavacTask extends AbstractTask { private boolean includeStandardOptions; - private String classpath; - private String sourcepath; - private String outdir; + private List classpath; + private List sourcepath; + private Path outdir; private List options; private List classes; private List files; private List fileObjects; private JavaFileManager fileManager; + private JavaCompiler compiler; + private StandardJavaFileManager internalFileManager; + /** * Creates a task to execute {@code javac} using API mode. */ @@ -898,7 +898,20 @@ public class ToolBox { * @return this task object */ public JavacTask classpath(String classpath) { - this.classpath = classpath; + this.classpath = Stream.of(classpath.split(File.pathSeparator)) + .filter(s -> !s.isEmpty()) + .map(s -> Paths.get(s)) + .collect(Collectors.toList()); + return this; + } + + /** + * Sets the classpath. + * @param classpath the classpath + * @return this task object + */ + public JavacTask classpath(Path... classpath) { + this.classpath = Arrays.asList(classpath); return this; } @@ -908,7 +921,20 @@ public class ToolBox { * @return this task object */ public JavacTask sourcepath(String sourcepath) { - this.sourcepath = sourcepath; + this.sourcepath = Stream.of(sourcepath.split(File.pathSeparator)) + .filter(s -> !s.isEmpty()) + .map(s -> Paths.get(s)) + .collect(Collectors.toList()); + return this; + } + + /** + * Sets the sourcepath. + * @param classpath the sourcepath + * @return this task object + */ + public JavacTask sourcepath(Path... sourcepath) { + this.sourcepath = Arrays.asList(sourcepath); return this; } @@ -918,6 +944,16 @@ public class ToolBox { * @return this task object */ public JavacTask outdir(String outdir) { + this.outdir = Paths.get(outdir); + return this; + } + + /** + * Sets the output directory. + * @param outdir the output directory + * @return this task object + */ + public JavacTask outdir(Path outdir) { this.outdir = outdir; return this; } @@ -1039,38 +1075,43 @@ public class ToolBox { } private int runAPI(PrintWriter pw) throws IOException { -// if (compiler == null) { - // TODO: allow this to be set externally -// compiler = ToolProvider.getSystemJavaCompiler(); - compiler = JavacTool.create(); -// } + try { +// if (compiler == null) { + // TODO: allow this to be set externally +// compiler = ToolProvider.getSystemJavaCompiler(); + compiler = JavacTool.create(); +// } - if (fileManager == null) - fileManager = compiler.getStandardFileManager(null, null, null); - if (outdir != null) - setLocation(StandardLocation.CLASS_OUTPUT, toFiles(outdir)); - if (classpath != null) - setLocation(StandardLocation.CLASS_PATH, toFiles(classpath)); - if (sourcepath != null) - setLocation(StandardLocation.SOURCE_PATH, toFiles(sourcepath)); - List allOpts = new ArrayList<>(); - if (options != null) - allOpts.addAll(options); + if (fileManager == null) + fileManager = internalFileManager = compiler.getStandardFileManager(null, null, null); + if (outdir != null) + setLocationFromPaths(StandardLocation.CLASS_OUTPUT, Collections.singletonList(outdir)); + if (classpath != null) + setLocationFromPaths(StandardLocation.CLASS_PATH, classpath); + if (sourcepath != null) + setLocationFromPaths(StandardLocation.SOURCE_PATH, sourcepath); + List allOpts = new ArrayList<>(); + if (options != null) + allOpts.addAll(options); - Iterable allFiles = joinFiles(files, fileObjects); - JavaCompiler.CompilationTask task = compiler.getTask(pw, - fileManager, - null, // diagnostic listener; should optionally collect diags - allOpts, - classes, - allFiles); - return ((JavacTaskImpl) task).doCall().exitCode; + Iterable allFiles = joinFiles(files, fileObjects); + JavaCompiler.CompilationTask task = compiler.getTask(pw, + fileManager, + null, // diagnostic listener; should optionally collect diags + allOpts, + classes, + allFiles); + return ((JavacTaskImpl) task).doCall().exitCode; + } finally { + if (internalFileManager != null) + internalFileManager.close(); + } } - private void setLocation(StandardLocation location, List files) throws IOException { + private void setLocationFromPaths(StandardLocation location, List files) throws IOException { if (!(fileManager instanceof StandardJavaFileManager)) throw new IllegalStateException("not a StandardJavaFileManager"); - ((StandardJavaFileManager) fileManager).setLocation(location, files); + ((StandardJavaFileManager) fileManager).setLocationFromPaths(location, files); } private int runCommand(PrintWriter pw) { @@ -1105,15 +1146,15 @@ public class ToolBox { args.addAll(options); if (outdir != null) { args.add("-d"); - args.add(outdir); + args.add(outdir.toString()); } if (classpath != null) { args.add("-classpath"); - args.add(classpath); + args.add(toSearchPath(classpath)); } if (sourcepath != null) { args.add("-sourcepath"); - args.add(sourcepath); + args.add(toSearchPath(sourcepath)); } if (classes != null) args.addAll(classes); @@ -1123,23 +1164,20 @@ public class ToolBox { return args; } - private List toFiles(String path) { - List result = new ArrayList<>(); - for (String s : path.split(File.pathSeparator)) { - if (!s.isEmpty()) - result.add(new File(s)); - } - return result; + private String toSearchPath(List files) { + return files.stream() + .map(Path::toString) + .collect(Collectors.joining(File.pathSeparator)); } private Iterable joinFiles( List files, List fileObjects) { if (files == null) return fileObjects; - if (standardJavaFileManager == null) - standardJavaFileManager = compiler.getStandardFileManager(null, null, null); + if (internalFileManager == null) + internalFileManager = compiler.getStandardFileManager(null, null, null); Iterable filesAsFileObjects = - standardJavaFileManager.getJavaFileObjectsFromStrings(files); + internalFileManager.getJavaFileObjectsFromStrings(files); if (fileObjects == null) return filesAsFileObjects; List combinedList = new ArrayList<>(); @@ -1363,6 +1401,15 @@ public class ToolBox { jar = Paths.get(path); } + /** + * Creates a JarTask for use with a given jar file. + * @param path the file + */ + public JarTask(Path path) { + this(); + jar = path; + } + /** * Sets a manifest for the jar file. * @param manifest the manifest @@ -1416,6 +1463,16 @@ public class ToolBox { return this; } + /** + * Sets the base directory for files to be written into the jar file. + * @param baseDir the base directory + * @return this task object + */ + public JarTask baseDir(Path baseDir) { + this.baseDir = baseDir; + return this; + } + /** * Sets the files to be written into the jar file. * @param files the files diff --git a/langtools/test/tools/sjavac/ExclPattern.java b/langtools/test/tools/sjavac/ExclPattern.java index 301dd297739..cd98da56082 100644 --- a/langtools/test/tools/sjavac/ExclPattern.java +++ b/langtools/test/tools/sjavac/ExclPattern.java @@ -21,7 +21,6 @@ * questions. */ - /* * @test * @bug 8037085