File: DeprecationSE8Test.java

package info (click to toggle)
openjdk-17 17.0.17%2B10-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 764,928 kB
  • sloc: java: 5,319,061; xml: 1,291,711; cpp: 1,202,358; ansic: 428,746; asm: 404,978; objc: 20,861; sh: 14,754; javascript: 10,743; python: 6,402; makefile: 2,404; perl: 357; awk: 351; sed: 172; jsp: 24; csh: 3
file content (47 lines) | stat: -rw-r--r-- 1,242 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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/**
 * @test  /nodynamiccopyright/
 * @bug 8065219
 * @summary Deprecated warning in method reference are missing in some cases.
 * @compile/ref=DeprecationSE8Test.noLint.out -XDrawDiagnostics DeprecationSE8Test.java
 * @compile/ref=DeprecationSE8Test.out -Xlint:deprecation,-options --release 8 -XDrawDiagnostics DeprecationSE8Test.java
 */


class DeprecationSE8Test {
    @FunctionalInterface
    interface I {
        DeprecationSE8Test meth();
    }

    @FunctionalInterface
    interface J {
        int meth();
    }

    @Deprecated
    public DeprecationSE8Test() {
    }

    @Deprecated
    public static int foo() {
        return 1;
    }

    // Using deprecated entities from within one's own top level class does not merit warning.
    void notBadUsages() {
        I i = DeprecationSE8Test::new;
        new DeprecationSE8Test();
        J j = DeprecationSE8Test::foo;
        foo();
    }
}

class DeprecationSE8_01 {
    // Using deprecated entities from outside one's own top level class deserves warning.
    void badUsages() {
        DeprecationSE8Test.I i = DeprecationSE8Test::new;
        new DeprecationSE8Test();
        DeprecationSE8Test.foo();
        DeprecationSE8Test.J j = DeprecationSE8Test::foo;
    }
}