aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-ws-client/src/main
diff options
context:
space:
mode:
authorEvgeny Mandrikov <mandrikov@gmail.com>2011-04-27 20:29:11 +0400
committerEvgeny Mandrikov <mandrikov@gmail.com>2011-04-27 22:10:58 +0400
commit25f963bfb953346ee85337009b1af7d665494aa0 (patch)
treef1ae028f197e0538460c5d3e349832915bf49bdb /sonar-ws-client/src/main
parent70c03e6ac1e0f24277655f9e7666142d9418d270 (diff)
downloadsonarqube-25f963bfb953346ee85337009b1af7d665494aa0.tar.gz
sonarqube-25f963bfb953346ee85337009b1af7d665494aa0.zip
SONAR-2386 Define contract for lineId in Violation
Value can be null or greater than zero, so setter must log warning if not null and less than 1. It will throw an exception in future releases.
Diffstat (limited to 'sonar-ws-client/src/main')
-rw-r--r--sonar-ws-client/src/main/java/org/sonar/wsclient/services/Violation.java22
1 files changed, 21 insertions, 1 deletions
diff --git a/sonar-ws-client/src/main/java/org/sonar/wsclient/services/Violation.java b/sonar-ws-client/src/main/java/org/sonar/wsclient/services/Violation.java
index 0d5b816425f..4e170124c6b 100644
--- a/sonar-ws-client/src/main/java/org/sonar/wsclient/services/Violation.java
+++ b/sonar-ws-client/src/main/java/org/sonar/wsclient/services/Violation.java
@@ -74,12 +74,32 @@ public class Violation extends Model {
this.severity = priority;
}
+ /**
+ * @return line number (numeration starts from 1), or <code>null</code> if violation doesn't belong to concrete line
+ * @see #hasLine()
+ */
public Integer getLine() {
return line;
}
public void setLine(Integer line) {
- this.line = line;
+ if (line != null && line < 1) {
+ /*
+ * This shouldn't happen, however line would be normalized to null if web service returns incorrect value (less than 1)
+ * in compliance with a contract for getLine method. Normalization added in 2.8 - see http://jira.codehaus.org/browse/SONAR-2386
+ */
+ this.line = null;
+ } else {
+ this.line = line;
+ }
+ }
+
+ /**
+ * @return <code>true<code> if violation belongs to concrete line
+ * @since 2.8
+ */
+ public boolean hasLine() {
+ return line != null;
}
public String getResourceKey() {