test/tools/javac/foreach/IntersectIterator.java

Sat, 01 Dec 2007 00:00:00 +0000

author
duke
date
Sat, 01 Dec 2007 00:00:00 +0000
changeset 1
9a66ca7c79fa
child 289
84061bd68019
permissions
-rw-r--r--

Initial load

duke@1 1 /*
duke@1 2 * Copyright 2004 Sun Microsystems, Inc. All Rights Reserved.
duke@1 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@1 4 *
duke@1 5 * This code is free software; you can redistribute it and/or modify it
duke@1 6 * under the terms of the GNU General Public License version 2 only, as
duke@1 7 * published by the Free Software Foundation.
duke@1 8 *
duke@1 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@1 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@1 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@1 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@1 13 * accompanied this code).
duke@1 14 *
duke@1 15 * You should have received a copy of the GNU General Public License version
duke@1 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@1 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@1 18 *
duke@1 19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
duke@1 20 * CA 95054 USA or visit www.sun.com if you need additional information or
duke@1 21 * have any questions.
duke@1 22 */
duke@1 23
duke@1 24 /*
duke@1 25 * @test
duke@1 26 * @bug 5003207
duke@1 27 * @summary new "for" statement fails to cast to second upper bound
duke@1 28 * @author gafter
duke@1 29 *
duke@1 30 * @compile -source 1.5 IntersectIterator.java
duke@1 31 * @run main IntersectIterator
duke@1 32 */
duke@1 33
duke@1 34 import java.util.*;
duke@1 35
duke@1 36 interface A {}
duke@1 37 interface B<T> extends Iterable<T> {}
duke@1 38 interface X {}
duke@1 39
duke@1 40 class C extends ArrayList<String> implements A, B<String> {
duke@1 41 C() {
duke@1 42 super(Arrays.<String>asList(new String[] {"Hello", "world"}));
duke@1 43 }
duke@1 44 }
duke@1 45
duke@1 46 class D implements A, X {
duke@1 47 final String s;
duke@1 48 D(String s) {
duke@1 49 this.s = s;
duke@1 50 }
duke@1 51 public String toString() {
duke@1 52 return s;
duke@1 53 }
duke@1 54 }
duke@1 55
duke@1 56 public class IntersectIterator {
duke@1 57
duke@1 58 static
duke@1 59 <T extends A & B<String>>
duke@1 60 void f(T t) {
duke@1 61 for (String s : t) System.out.println(s);
duke@1 62 }
duke@1 63 static
duke@1 64 <T extends A & X>
duke@1 65 void f(Iterable<T> t) {
duke@1 66 for (A a : t) System.out.println(a);
duke@1 67 for (X x : t) System.out.println(x);
duke@1 68 }
duke@1 69
duke@1 70 public static void main(String[] args) {
duke@1 71 f(new C());
duke@1 72 f(Arrays.<D>asList(new D[] {new D("Hello"), new D("world")}));
duke@1 73 }
duke@1 74 }

mercurial