From 21c037bb9bb7ca2c1990812a512aae22b9737f7a Mon Sep 17 00:00:00 2001 From: Maurizio Cimadamore Date: Wed, 5 Jan 2011 09:59:01 +0000 Subject: [PATCH] 7010194: several langtools regression failures after JSR 292 changes (b123) Some regression tests rely on unsupported JSR 292 features Reviewed-by: jjg --- .../TypeParameterOnPolymorphicSignature.java | 6 +- .../test/tools/javac/meth/InvokeDyn.java | 64 ------------------- .../test/tools/javac/meth/InvokeDynTrans.java | 59 ----------------- .../test/tools/javac/meth/XlintWarn.java | 8 +-- 4 files changed, 7 insertions(+), 130 deletions(-) delete mode 100644 langtools/test/tools/javac/meth/InvokeDyn.java delete mode 100644 langtools/test/tools/javac/meth/InvokeDynTrans.java diff --git a/langtools/test/tools/javac/diags/examples/TypeParameterOnPolymorphicSignature.java b/langtools/test/tools/javac/diags/examples/TypeParameterOnPolymorphicSignature.java index 77a02b9c52e..fc23fde5412 100644 --- a/langtools/test/tools/javac/diags/examples/TypeParameterOnPolymorphicSignature.java +++ b/langtools/test/tools/javac/diags/examples/TypeParameterOnPolymorphicSignature.java @@ -24,8 +24,10 @@ // key: compiler.warn.type.parameter.on.polymorphic.signature // key: compiler.err.unreported.exception.need.to.catch.or.throw -import java.dyn.InvokeDynamic; +import java.dyn.MethodHandle; class TypeParameterOnPolymorphicSignature { - { InvokeDynamic.call("",123); } + void test(MethodHandle mh) { + mh.invokeExact("",123); + } } diff --git a/langtools/test/tools/javac/meth/InvokeDyn.java b/langtools/test/tools/javac/meth/InvokeDyn.java deleted file mode 100644 index 6285e8c1be1..00000000000 --- a/langtools/test/tools/javac/meth/InvokeDyn.java +++ /dev/null @@ -1,64 +0,0 @@ -/* - * Copyright (c) 2008, 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. - */ - -/* - * @test - * @bug 6754038 6979327 - * @summary Generate call sites for method handle - * @author jrose - * - * @library .. - * @compile -source 7 -target 7 -XDinvokedynamic -XDallowTransitionalJSR292=no InvokeDyn.java - */ -//No: @run main/othervm -XX:+EnableInvokeDynamic meth.InvokeDyn - -/* - * Standalone testing: - * - * $ cd $MY_REPO_DIR/langtools - * $ (cd make; make) - * $ ./dist/bootstrap/bin/javac -d dist test/tools/javac/meth/InvokeDyn.java - * $ javap -c -classpath dist meth.InvokeDyn - * - */ - -package meth; - -import java.dyn.*; - -public class InvokeDyn { - class CS extends CallSite { - CS(Object x, Object y, Object z) { throw new RuntimeException(); } - } - //@BootstrapMethod(CS.class) //note: requires 6964498 - void test() throws Throwable { - Object x = "hello"; - Object ojunk; int ijunk; - ojunk = InvokeDynamic.greet(x, "world", 123); - ojunk = InvokeDynamic.greet(x, "mundus", 456); - ojunk = InvokeDynamic.greet(x, "kosmos", 789); - ojunk = (String) InvokeDynamic.cogitate(10.11121, 3.14); - //InvokeDynamic.#"yow: what I mean to say is, please treat this one specially"(null); - ijunk = (int) InvokeDynamic.invoke("goodbye"); - } -} diff --git a/langtools/test/tools/javac/meth/InvokeDynTrans.java b/langtools/test/tools/javac/meth/InvokeDynTrans.java deleted file mode 100644 index 092d649923b..00000000000 --- a/langtools/test/tools/javac/meth/InvokeDynTrans.java +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright (c) 2008, 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. - */ - -/* - * @test - * @bug 6754038 6979327 - * @summary Generate call sites for method handle - * @author jrose - * - * @library .. - * @compile/fail/ref=InvokeDynTrans.out -Werror -XDrawDiagnostics -source 7 -target 7 InvokeDynTrans.java - */ -//No: @run main/othervm -XX:+EnableInvokeDynamic meth.InvokeDyn - -/* - * Standalone testing: - * - * $ cd $MY_REPO_DIR/langtools - * $ (cd make; make) - * $ ./dist/bootstrap/bin/javac -d dist test/tools/javac/meth/InvokeDyn.java - * $ javap -c -classpath dist meth.InvokeDyn - * - */ - -package meth; - -import java.dyn.InvokeDynamic; - -public class InvokeDynTrans { - void test() throws Throwable { - Object x = "hello"; - InvokeDynamic.greet(x, "world", 123); - InvokeDynamic.greet(x, "mundus", 456); - InvokeDynamic.greet(x, "kosmos", 789); - InvokeDynamic.cogitate(10.11121, 3.14); - //InvokeDynamic.#"yow: what I mean to say is, please treat this one specially"(null); - InvokeDynamic.invoke("goodbye"); - } -} diff --git a/langtools/test/tools/javac/meth/XlintWarn.java b/langtools/test/tools/javac/meth/XlintWarn.java index 294cd34f106..844994b8e69 100644 --- a/langtools/test/tools/javac/meth/XlintWarn.java +++ b/langtools/test/tools/javac/meth/XlintWarn.java @@ -23,7 +23,7 @@ /* * @test - * @bug 6999067 + * @bug 6999067 7010194 * @summary cast for invokeExact call gets redundant cast to warnings * @author mcimadamore * @@ -34,9 +34,7 @@ import java.dyn.*; class XlintWarn { void test(MethodHandle mh) throws Throwable { - int i1 = (int)mh.invoke(); - int i2 = (int)mh.invokeExact(); - int i3 = (int)mh.invokeVarargs(); - int i4 = (int)InvokeDynamic.test(); + int i1 = (int)mh.invokeExact(); + int i2 = (int)mh.invokeVarargs(); } }