jjg@309: jjg@309: /* ohair@798: * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. jjg@309: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. jjg@309: * jjg@309: * This code is free software; you can redistribute it and/or modify it jjg@309: * under the terms of the GNU General Public License version 2 only, as jjg@309: * published by the Free Software Foundation. jjg@309: * jjg@309: * This code is distributed in the hope that it will be useful, but WITHOUT jjg@309: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or jjg@309: * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License jjg@309: * version 2 for more details (a copy is included in the LICENSE file that jjg@309: * accompanied this code). jjg@309: * jjg@309: * You should have received a copy of the GNU General Public License version jjg@309: * 2 along with this work; if not, write to the Free Software Foundation, jjg@309: * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. jjg@309: * ohair@554: * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ohair@554: * or visit www.oracle.com if you need additional information or have any ohair@554: * questions. jjg@309: */ jjg@309: jjg@309: /* jjg@309: * @test jjg@309: * @bug 6843077 jjg@309: * @summary random tests for new locations jjg@309: * @author Matt Papi jjg@722: * @compile/fail/ref=BasicTest.out -XDrawDiagnostics BasicTest.java jjg@309: */ jjg@309: jjg@309: import java.util.*; jjg@309: import java.io.*; jjg@309: jjg@309: @interface A {} jjg@309: @interface B {} jjg@309: @interface C {} jjg@309: @interface D {} jjg@309: jjg@722: //308: Test inverted to verify that type annotations can not be parsed yet. jjg@722: jjg@309: /** jjg@309: * Tests basic JSR 308 parser functionality. We don't really care about what jjg@309: * the parse tree looks like, just that these annotations can be parsed. jjg@309: */ jjg@309: class BasicTest extends @B LinkedList implements @C List { jjg@309: jjg@309: void test() { jjg@309: jjg@309: // Handle annotated class literals/cast types jjg@309: Class c = @A String.class; jjg@309: Object o = (@A Object) "foo"; jjg@309: jjg@309: // Handle annotated "new" expressions (except arrays; see ArrayTest) jjg@309: String s = new @A String("bar"); jjg@309: jjg@309: boolean b = o instanceof @A Object; jjg@309: jjg@309: jjg@309: @A Map<@B List<@C String>, @D String> map = jjg@309: new @A HashMap<@B List<@C String>, @D String>(); jjg@309: jjg@309: Class c2 = @A String.class; jjg@309: } jjg@309: jjg@309: // Handle receiver annotations jjg@309: // Handle annotations on a qualified identifier list jjg@309: void test2() @C @D throws @A IllegalArgumentException, @B IOException { jjg@309: jjg@309: } jjg@309: jjg@309: // Handle annotations on a varargs element type jjg@309: void test3(Object @A... objs) { jjg@309: jjg@309: } jjg@309: }