aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-plugin-api
diff options
context:
space:
mode:
authorJulien Lancelot <julien.lancelot@sonarsource.com>2016-04-06 10:31:09 +0200
committerJulien Lancelot <julien.lancelot@sonarsource.com>2016-04-06 10:31:15 +0200
commitc7662baa5b3c54e0627f88796728e2e0da1f70fb (patch)
treec617fec7dc8da19a21e7003602489f0eb4eef11e /sonar-plugin-api
parent9e8e346e71b304fcf7aeb4e4f4c9a3c7107e1a53 (diff)
downloadsonarqube-c7662baa5b3c54e0627f88796728e2e0da1f70fb.tar.gz
sonarqube-c7662baa5b3c54e0627f88796728e2e0da1f70fb.zip
Fix quality flaws
Diffstat (limited to 'sonar-plugin-api')
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/rules/RuleType.java23
-rw-r--r--sonar-plugin-api/src/test/java/org/sonar/api/rules/RuleTypeTest.java4
2 files changed, 21 insertions, 6 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/rules/RuleType.java b/sonar-plugin-api/src/main/java/org/sonar/api/rules/RuleType.java
index 66222702a69..5755b8050fb 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/rules/RuleType.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/rules/RuleType.java
@@ -19,16 +19,18 @@
*/
package org.sonar.api.rules;
-import com.google.common.base.Enums;
-import com.google.common.collect.Lists;
-import java.util.List;
+import com.google.common.base.Function;
+import java.util.Arrays;
+import java.util.Set;
+import javax.annotation.Nonnull;
+import static com.google.common.collect.FluentIterable.from;
import static java.lang.String.format;
public enum RuleType {
CODE_SMELL(1), BUG(2), VULNERABILITY(3);
- public static final List<String> ALL_NAMES = Lists.transform(Lists.newArrayList(values()), Enums.stringConverter(RuleType.class).reverse());
+ private static final Set<String> ALL_NAMES = from(Arrays.asList(values())).transform(ToName.INSTANCE).toSet();
private final int dbConstant;
@@ -40,6 +42,10 @@ public enum RuleType {
return dbConstant;
}
+ public static Set<String> names() {
+ return ALL_NAMES;
+ }
+
/**
* Returns the enum constant of the specified DB column value.
*/
@@ -53,4 +59,13 @@ public enum RuleType {
throw new IllegalArgumentException(format("Unsupported type value : %d", dbConstant));
}
+ private enum ToName implements Function<RuleType, String> {
+ INSTANCE;
+
+ @Override
+ public String apply(@Nonnull RuleType input) {
+ return input.name();
+ }
+ }
+
}
diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/rules/RuleTypeTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/rules/RuleTypeTest.java
index 54f914049bf..a2ecc6cddf9 100644
--- a/sonar-plugin-api/src/test/java/org/sonar/api/rules/RuleTypeTest.java
+++ b/sonar-plugin-api/src/test/java/org/sonar/api/rules/RuleTypeTest.java
@@ -45,12 +45,12 @@ public class RuleTypeTest {
@Test
public void test_ALL_NAMES() {
- assertThat(RuleType.ALL_NAMES).containsOnly("BUG", "VULNERABILITY", "CODE_SMELL");
+ assertThat(RuleType.names()).containsOnly("BUG", "VULNERABILITY", "CODE_SMELL");
}
@Test
public void ALL_NAMES_is_immutable() {
expectedException.expect(UnsupportedOperationException.class);
- RuleType.ALL_NAMES.add("foo");
+ RuleType.names().add("foo");
}
}