mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-28 23:34:52 +02:00
8187443: Forest Consolidation: Move files to unified layout
Reviewed-by: darcy, ihse
This commit is contained in:
parent
270fe13182
commit
3789983e89
56923 changed files with 3 additions and 15727 deletions
46
test/langtools/tools/javac/lambda/MethodReference64.java
Normal file
46
test/langtools/tools/javac/lambda/MethodReference64.java
Normal file
|
@ -0,0 +1,46 @@
|
|||
/*
|
||||
* @test /nodynamiccopyright/
|
||||
* @bug 8008540 8008539 8008538
|
||||
* @summary Constructor reference to non-reifiable array should be rejected
|
||||
* @compile/fail/ref=MethodReference64.out -XDrawDiagnostics MethodReference64.java
|
||||
*/
|
||||
class MethodReference64 {
|
||||
interface ClassFactory {
|
||||
Object m();
|
||||
}
|
||||
|
||||
interface ArrayFactory {
|
||||
Object m(int i);
|
||||
}
|
||||
|
||||
@interface Anno { }
|
||||
|
||||
enum E { }
|
||||
|
||||
interface I { }
|
||||
|
||||
static class Foo<X> { }
|
||||
|
||||
void m(ClassFactory cf) { }
|
||||
void m(ArrayFactory cf) { }
|
||||
|
||||
void testAssign() {
|
||||
ClassFactory c1 = Anno::new; //error
|
||||
ClassFactory c2 = E::new; //error
|
||||
ClassFactory c3 = I::new; //error
|
||||
ClassFactory c4 = Foo<?>::new; //error
|
||||
ClassFactory c5 = 1::new; //error
|
||||
ArrayFactory a1 = Foo<?>[]::new; //ok
|
||||
ArrayFactory a2 = Foo<? extends String>[]::new; //error
|
||||
}
|
||||
|
||||
void testMethod() {
|
||||
m(Anno::new); //error
|
||||
m(E::new); //error
|
||||
m(I::new); //error
|
||||
m(Foo<?>::new); //error
|
||||
m(1::new); //error
|
||||
m(Foo<?>[]::new); //ok - resolves to m(ArrayFactory)
|
||||
m(Foo<? extends String>[]::new); //error
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue