File: AnalyzerNotQuiteSpeculative.java

package info (click to toggle)
openjdk-25 25.0.1%2B8-1~deb13u1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 825,408 kB
  • sloc: java: 5,585,680; cpp: 1,333,948; xml: 1,321,242; ansic: 488,034; asm: 404,003; objc: 21,088; sh: 15,106; javascript: 13,265; python: 8,319; makefile: 2,518; perl: 357; awk: 351; pascal: 103; exp: 83; sed: 72; jsp: 24
file content (25 lines) | stat: -rw-r--r-- 781 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/**
 * @test /nodynamiccopyright/
 * @bug 8230105
 * @summary Ensuring speculative analysis on behalf of Analyzers works reasonably.
 * @compile/ref=AnalyzerNotQuiteSpeculative.out -XDfind=diamond -XDrawDiagnostics AnalyzerNotQuiteSpeculative.java
 */
public class AnalyzerNotQuiteSpeculative {
    private void test() {
        Subclass1 c1 = null;
        Subclass2 c2 = null;
        Base b = null;

        t(new C<Base>(c1).set(c2));
        t(new C<Base>(b).set(c2));
    }

    public static class Base {}
    public static class Subclass1 extends Base {}
    public static class Subclass2 extends Base {}
    public class C<T extends Base> {
        public C(T t) {}
        public C<T> set(T t) { return this; }
    }
    <T extends Base> void t(C<? extends Base> l) {}
}