aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-plugin-api/src/main/java/org/sonar/api
diff options
context:
space:
mode:
authorJulien Lancelot <julien.lancelot@gmail.com>2013-07-11 17:10:08 +0200
committerJulien Lancelot <julien.lancelot@gmail.com>2013-07-11 17:10:08 +0200
commitd217475442c8b463724626325f27ff5bfe06fc14 (patch)
tree2d5145c9da4e7f46b9c31d58253c615009d746a3 /sonar-plugin-api/src/main/java/org/sonar/api
parent014ba2d48296a2b98349ee4cd16a4767b737c239 (diff)
downloadsonarqube-d217475442c8b463724626325f27ff5bfe06fc14.tar.gz
sonarqube-d217475442c8b463724626325f27ff5bfe06fc14.zip
Add some CheckForNull and Nullable annotations
Diffstat (limited to 'sonar-plugin-api/src/main/java/org/sonar/api')
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/i18n/I18n.java6
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/i18n/RuleI18n.java5
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/i18n/package-info.java23
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/rules/Rule.java8
4 files changed, 39 insertions, 3 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/i18n/I18n.java b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/I18n.java
index 7ce619b9c42..2588ea5d58f 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/i18n/I18n.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/I18n.java
@@ -22,6 +22,9 @@ package org.sonar.api.i18n;
import org.sonar.api.BatchComponent;
import org.sonar.api.ServerComponent;
+import javax.annotation.CheckForNull;
+import javax.annotation.Nullable;
+
import java.util.Locale;
/**
@@ -45,6 +48,7 @@ public interface I18n extends ServerComponent, BatchComponent {
* @param parameters the parameters used to format the message from the translated pattern.
* @return the message formatted with the translated pattern and the given parameters
*/
- String message(final Locale locale, final String key, final String defaultValue, final Object... parameters);
+ @CheckForNull
+ String message(final Locale locale, final String key, @Nullable final String defaultValue, final Object... parameters);
}
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/i18n/RuleI18n.java b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/RuleI18n.java
index 5cb5e002187..9b06cee3180 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/i18n/RuleI18n.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/RuleI18n.java
@@ -23,6 +23,8 @@ import org.sonar.api.BatchComponent;
import org.sonar.api.ServerComponent;
import org.sonar.api.rules.Rule;
+import javax.annotation.CheckForNull;
+
import java.util.Locale;
/**
@@ -43,6 +45,7 @@ public interface RuleI18n extends ServerComponent, BatchComponent {
* @param locale the locale to translate into
* @return the translated name of the rule, or the default English one if the given locale is not supported, or null
*/
+ @CheckForNull
String getName(String repositoryKey, String ruleKey, Locale locale);
/**
@@ -55,6 +58,7 @@ public interface RuleI18n extends ServerComponent, BatchComponent {
* @param locale the locale to translate into
* @return the translated name of the rule, or the default English one if the given locale is not supported, or the rule name.
*/
+ @CheckForNull
String getName(Rule rule, Locale locale);
/**
@@ -83,6 +87,7 @@ public interface RuleI18n extends ServerComponent, BatchComponent {
* @return the translated name of the rule parameter, or the default English one if the given locale is not supported, or null if
* no translation can be found.
*/
+ @CheckForNull
String getParamDescription(String repositoryKey, String ruleKey, String paramKey, Locale locale);
}
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/i18n/package-info.java b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/package-info.java
new file mode 100644
index 00000000000..616332a1c32
--- /dev/null
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/i18n/package-info.java
@@ -0,0 +1,23 @@
+/*
+ * SonarQube, open source software quality management tool.
+ * Copyright (C) 2008-2013 SonarSource
+ * mailto:contact AT sonarsource DOT com
+ *
+ * SonarQube is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * SonarQube is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+@ParametersAreNonnullByDefault
+package org.sonar.api.i18n;
+
+import javax.annotation.ParametersAreNonnullByDefault; \ No newline at end of file
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/rules/Rule.java b/sonar-plugin-api/src/main/java/org/sonar/api/rules/Rule.java
index 79eae5c38b2..02612902def 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/rules/Rule.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/rules/Rule.java
@@ -32,6 +32,8 @@ import org.sonar.api.rule.RuleKey;
import org.sonar.api.utils.SonarException;
import org.sonar.check.Cardinality;
+import javax.annotation.CheckForNull;
+import javax.annotation.Nullable;
import javax.persistence.*;
import java.util.ArrayList;
@@ -205,6 +207,7 @@ public final class Rule {
this.id = id;
}
+ @CheckForNull
public String getName() {
return name;
}
@@ -212,7 +215,7 @@ public final class Rule {
/**
* Sets the rule name
*/
- public Rule setName(String name) {
+ public Rule setName(@Nullable String name) {
this.name = removeNewLineCharacters(name);
return this;
}
@@ -504,7 +507,8 @@ public final class Rule {
.toString();
}
- private String removeNewLineCharacters(String text) {
+ @CheckForNull
+ private String removeNewLineCharacters(@Nullable String text) {
String removedCRLF = StringUtils.remove(text, "\n");
removedCRLF = StringUtils.remove(removedCRLF, "\r");
removedCRLF = StringUtils.remove(removedCRLF, "\n\r");