2023-05-03 11:06:20 +02:00
|
|
|
== Why is this an issue?
|
|
|
|
|
2021-04-28 16:49:39 +02:00
|
|
|
According to http://docs.oracle.com/javase/specs/jls/se7/html/jls-8.html#jls-8.9[the Java Language Specification-8.9]:
|
|
|
|
|
|
|
|
____
|
|
|
|
Nested enum types are implicitly ``++static++``.
|
|
|
|
____
|
|
|
|
|
|
|
|
|
|
|
|
So there's no need to declare them ``++static++`` explicitly.
|
|
|
|
|
2021-04-28 18:08:03 +02:00
|
|
|
|
2023-05-03 11:06:20 +02:00
|
|
|
=== Noncompliant code example
|
2021-04-28 16:49:39 +02:00
|
|
|
|
2022-02-04 17:28:24 +01:00
|
|
|
[source,java]
|
2021-04-28 16:49:39 +02:00
|
|
|
----
|
|
|
|
public class Flower {
|
|
|
|
static enum Color { // Noncompliant; static is redundant here
|
|
|
|
RED, YELLOW, BLUE, ORANGE
|
|
|
|
}
|
|
|
|
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
----
|
|
|
|
|
2021-04-28 18:08:03 +02:00
|
|
|
|
2023-05-03 11:06:20 +02:00
|
|
|
=== Compliant solution
|
2021-04-28 16:49:39 +02:00
|
|
|
|
2022-02-04 17:28:24 +01:00
|
|
|
[source,java]
|
2021-04-28 16:49:39 +02:00
|
|
|
----
|
|
|
|
public class Flower {
|
|
|
|
enum Color { // Compliant
|
|
|
|
RED, YELLOW, BLUE, ORANGE
|
|
|
|
}
|
|
|
|
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
----
|
2021-04-28 18:08:03 +02:00
|
|
|
|
|
|
|
|
2021-06-02 20:44:38 +02:00
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
ifdef::env-github,rspecator-view[]
|
2021-09-20 15:38:42 +02:00
|
|
|
|
|
|
|
'''
|
|
|
|
== Implementation Specification
|
|
|
|
(visible only on this page)
|
|
|
|
|
2023-05-25 14:18:12 +02:00
|
|
|
=== Message
|
|
|
|
|
|
|
|
Remove this redundant "static" qualifier; nested enum types are implicitly static.
|
|
|
|
|
|
|
|
|
|
|
|
=== Highlighting
|
|
|
|
|
|
|
|
Primary Location: the 'static' keyword
|
|
|
|
|
|
|
|
Secondary Location: the 'enum' keyword
|
2021-09-20 15:38:42 +02:00
|
|
|
|
|
|
|
|
2021-06-08 15:52:13 +02:00
|
|
|
'''
|
2021-06-02 20:44:38 +02:00
|
|
|
== Comments And Links
|
|
|
|
(visible only on this page)
|
|
|
|
|
2023-05-25 14:18:12 +02:00
|
|
|
=== on 31 Mar 2015, 15:09:56 Nicolas Peru wrote:
|
|
|
|
\[~ann.campbell.2]could be nice to add a link or a quote from the jls : \http://docs.oracle.com/javase/specs/jls/se7/html/jls-8.html#jls-8.9
|
|
|
|
|
|
|
|
|
|
|
|
____
|
|
|
|
Nested enum types are implicitly static. It is permissible to explicitly declare a nested enum type to be static.
|
|
|
|
|
|
|
|
____
|
|
|
|
|
|
|
|
=== on 31 Mar 2015, 17:46:06 Ann Campbell wrote:
|
|
|
|
\[~nicolas.peru] why would we quote the docs as saying it's permissible to do exactly what this rule says not to do?
|
|
|
|
|
|
|
|
=== on 1 Apr 2015, 08:42:30 Nicolas Peru wrote:
|
|
|
|
Then let's just keep the first part of the sentence :
|
|
|
|
|
|
|
|
____
|
|
|
|
Nested enum types are implicitly static.
|
|
|
|
|
|
|
|
____
|
|
|
|
point is to refer to the correct section of the JLS to let user know we did not invent this.
|
|
|
|
|
|
|
|
=== on 1 Apr 2015, 17:06:42 Ann Campbell wrote:
|
|
|
|
Done [~nicolas.peru]
|
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
endif::env-github,rspecator-view[]
|