aboutsummaryrefslogtreecommitdiff
path: root/src/core/lombok/javac
diff options
context:
space:
mode:
authorReinier Zwitserloot <r.zwitserloot@projectlombok.org>2021-10-26 04:14:46 +0200
committerReinier Zwitserloot <r.zwitserloot@projectlombok.org>2021-10-26 04:14:46 +0200
commit3a0176fd907ec594194cabf843a5681fd7b811fd (patch)
treed40257a3a2583974f936234e01c601a8c2fc4b0c /src/core/lombok/javac
parentc359a4b41f2800c63ad28037fe02ccf8910dcc2e (diff)
downloadlombok-3a0176fd907ec594194cabf843a5681fd7b811fd.tar.gz
lombok-3a0176fd907ec594194cabf843a5681fd7b811fd.tar.bz2
lombok-3a0176fd907ec594194cabf843a5681fd7b811fd.zip
[fixes #3014] Detecting whether inner classes are static wouldn't work if placed inside an enum or interface.
Diffstat (limited to 'src/core/lombok/javac')
-rw-r--r--src/core/lombok/javac/JavacNode.java8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/core/lombok/javac/JavacNode.java b/src/core/lombok/javac/JavacNode.java
index 035f7c53..fca0d0d1 100644
--- a/src/core/lombok/javac/JavacNode.java
+++ b/src/core/lombok/javac/JavacNode.java
@@ -286,13 +286,15 @@ public class JavacNode extends lombok.core.LombokNode<JavacAST, JavacNode, JCTre
@Override public boolean isStatic() {
if (node instanceof JCClassDecl) {
+ JCClassDecl t = (JCClassDecl) node;
+ long f = t.mods.flags;
+ if (((Flags.INTERFACE | Flags.ENUM) & f) != 0) return true;
JavacNode directUp = directUp();
if (directUp == null || directUp.getKind() == Kind.COMPILATION_UNIT) return true;
if (!(directUp.get() instanceof JCClassDecl)) return false;
JCClassDecl p = (JCClassDecl) directUp.get();
- long f = p.mods.flags;
- if ((Flags.INTERFACE & f) != 0) return true;
- if ((Flags.ENUM & f) != 0) return true;
+ f = p.mods.flags;
+ if (((Flags.INTERFACE | Flags.ENUM) & f) != 0) return true;
}
if (node instanceof JCVariableDecl) {