a494f0ab86
Turn on lambda expression, method reference and default method support Reviewed-by: jjg
139 lines
5.4 KiB
Java
139 lines
5.4 KiB
Java
/*
|
|
* Copyright (c) 2011, 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.
|
|
*/
|
|
|
|
/*SAM types:
|
|
1. An interface that has a single abstract method
|
|
2. Having more than one distinct methods, but only one is "real", the others are overriden public methods in Object - example: Comparator<T>
|
|
3. Having more than one methods due to inheritance, but they have the same signature
|
|
4. Having more than one methods due to inheritance, but one of them has a subsignature of all other methods
|
|
a) parameter types compatible
|
|
b) return type substitutable
|
|
c) thrown type not conflicting with the thrown clause of any other method
|
|
d) mixed up
|
|
5. Type-dependent SAM types
|
|
non-SAM types:
|
|
6. An interface that has a single abstract method, which is also public method in Object
|
|
7. Having more than one methods due to inheritance, and none of them has a subsignature of all other methods
|
|
*/
|
|
|
|
import java.util.List;
|
|
import java.util.Collection;
|
|
import java.sql.SQLException;
|
|
import java.sql.SQLTransientException;
|
|
import java.util.concurrent.TimeoutException;
|
|
import java.io.*;
|
|
|
|
interface A {int getOldest(List<Number> list);}
|
|
interface B {int getOldest(List list);}
|
|
interface C {int getOldest(List<?> list);}
|
|
interface D {int getOldest(List<Integer> list);}
|
|
interface E {int getOldest(Collection<?> collection);}
|
|
//Not SAM type, case #7
|
|
interface DE extends D, E {}
|
|
|
|
interface Foo {int getAge(Number n);}
|
|
interface Bar {int getAge(Integer i);}
|
|
//Not SAM type, case #7
|
|
interface FooBar extends Foo, Bar {}
|
|
|
|
//Not SAM type, case #6
|
|
interface Planet {boolean equals(Object o);}
|
|
|
|
// SAM type interfaces:
|
|
// type #2:
|
|
//only one abstract non-Ojbect method getAge()
|
|
interface Mars<T> extends Planet {int getAge(T t);}
|
|
//only one abstract non-Ojbect method increment()
|
|
interface Jupiter {
|
|
boolean equals(Object o);
|
|
String toString();
|
|
int increment(int i);
|
|
}
|
|
|
|
// type #3:
|
|
interface X {int getTotal(List<String> arg);}
|
|
interface Y {int getTotal(List<String> strs);}
|
|
//SAM type ([List<String>], int, {})
|
|
interface XY extends X, Y {}
|
|
//SAM type ([List<String>], int, {})
|
|
interface XYZ extends X, Y, XY {}
|
|
|
|
// type #4 a):
|
|
//SAM type ([List], int, {})
|
|
interface AB extends A, B {}
|
|
|
|
// type #4 b):
|
|
interface F {Number getValue(String str);}
|
|
interface G {Integer getValue(String str);}
|
|
interface H {Serializable getValue(String str);}
|
|
interface I {Object getValue(String str);}
|
|
//SAM type ([String], Integer, {})
|
|
interface FGHI extends F, G, H, I {}
|
|
|
|
interface J {List<Number> getAll(String str);}
|
|
interface K {List<?> getAll(String str);}
|
|
interface L {List getAll(String str);}
|
|
interface M {Collection getAll(String str);}
|
|
//SAM type ([String], List<Number>/List, {}) - the return type is flexible to some degree
|
|
interface JK extends J, K {}
|
|
//SAM type ([String], List<Number>/List, {})
|
|
interface JL extends J, L {}
|
|
//SAM type ([String], List<Number>/List, {})
|
|
interface JKL extends J, K, L {}
|
|
//SAM type ([String], List<Number>/List, {})
|
|
interface JKLM extends J, K, L, M {}
|
|
|
|
// type #4 c):
|
|
interface N {String getText(File f) throws IOException;}
|
|
interface O {String getText(File f) throws FileNotFoundException;}
|
|
interface P {String getText(File f) throws NullPointerException;}
|
|
//SAM type ([File], String, {FileNotFoundException})
|
|
interface NO extends N, O {}
|
|
//SAM type ([File], String, {})
|
|
interface NOP extends N, O, P {}
|
|
|
|
interface Boo {int getAge(String s) throws IOException;}
|
|
interface Doo {int getAge(String s) throws SQLException;}
|
|
//SAM type ([String], int, {})
|
|
interface BooDoo extends Boo, Doo {}
|
|
|
|
// type #4 d):
|
|
interface Q {Iterable m(Iterable<String> arg);}
|
|
interface R {Iterable<String> m(Iterable arg);}
|
|
//SAM type ([Iterable], Iterable<String>/Iterable, {})
|
|
interface QR extends Q, R {}
|
|
|
|
interface U {Collection foo(List<String> arg) throws IOException, SQLTransientException;}
|
|
interface V {List<?> foo(List<String> arg) throws EOFException, SQLException, TimeoutException;}
|
|
interface W {List<String> foo(List arg) throws Exception;}
|
|
//SAM type ([List<String>], List<String>/List, {EOFException, SQLTransientException})
|
|
interface UV extends U, V {}
|
|
// SAM type ([List], List<String>/List, {EOFException, SQLTransientException})
|
|
interface UVW extends U, V, W {}
|
|
|
|
// type #5:
|
|
// Not a SAM because sam-ness depends on instantiation of type-variables
|
|
interface Qoo<T> {void m(T arg);}
|
|
interface Roo<S extends Number> {void m(S arg);}
|
|
interface QooRoo<T1, T2 extends Number, T3> extends Qoo<T1>, Roo<T2> {}
|