RFR: 8178701: Compile error with switch statement on protected enum defined in parent inner class

Jan Lahoda jlahoda at openjdk.java.net
Fri Feb 25 12:39:32 UTC 2022


Consider the following code in two packages:

package foo;

import bar.D.E;

public class A {

    public static class B {

        protected enum C {
            X, Y, Z
        }
    }

    public static void main(String... args) {
        new E().run(B.C.X);
    }
}



package bar;

import foo.A.B;

public class D {

    public static class E extends B {

        public void run(C arg) {
            switch (arg) {
                default:
                    System.out.println("OK");
            }
        }
    }
}


Accessing `foo.A.B.C` in `bar.D.E` is OK, as it is accessible through the `E`'s superclass. But, for the `switch`, javac creates a map (array) from runtime ordinals of constants of `E` to compile-time positions. But, this mapping is in a different class that does not extend `B`, so internal method lookups fail for it, as the methods are not accessible per Java rules.

But, at runtime, the enum class is effectively public, so I think it is possible to ignore the protected access rules and accept the method invocations while generatting the mapping code, which is what this patch is trying to do.

-------------

Commit messages:
 - 8178701: Compile error with switch statement on protected enum defined in parent inner class

Changes: https://git.openjdk.java.net/jdk/pull/7621/files
 Webrev: https://webrevs.openjdk.java.net/?repo=jdk&pr=7621&range=00
  Issue: https://bugs.openjdk.java.net/browse/JDK-8178701
  Stats: 184 lines in 4 files changed: 137 ins; 0 del; 47 mod
  Patch: https://git.openjdk.java.net/jdk/pull/7621.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/7621/head:pull/7621

PR: https://git.openjdk.java.net/jdk/pull/7621


More information about the compiler-dev mailing list