aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/highlighting/DefaultHighlightingBuilder.java2
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingData.java2
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilder.java3
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRule.java10
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRuleValueCoder.java5
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/mediumtest/BatchMediumTester.java9
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/source/DefaultHighlightable.java4
-rw-r--r--sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilderTest.java25
-rw-r--r--sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataTest.java15
-rw-r--r--sonar-batch/src/test/java/org/sonar/batch/mediumtest/highlighting/HighlightingMediumTest.java10
10 files changed, 49 insertions, 36 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/highlighting/DefaultHighlightingBuilder.java b/sonar-batch/src/main/java/org/sonar/batch/highlighting/DefaultHighlightingBuilder.java
index 786ad0cca68..1399f66a438 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/highlighting/DefaultHighlightingBuilder.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/highlighting/DefaultHighlightingBuilder.java
@@ -40,7 +40,7 @@ public class DefaultHighlightingBuilder implements HighlightingBuilder {
@Override
public HighlightingBuilder highlight(int startOffset, int endOffset, TypeOfText typeOfText) {
Preconditions.checkState(!done, "done() already called");
- builder.registerHighlightingRule(startOffset, endOffset, typeOfText.cssClass());
+ builder.registerHighlightingRule(startOffset, endOffset, typeOfText);
return this;
}
diff --git a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingData.java b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingData.java
index 8e4f5314ec6..2a539efe189 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingData.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingData.java
@@ -47,7 +47,7 @@ public class SyntaxHighlightingData implements Data {
.append(FIELD_SEPARATOR)
.append(highlightingRule.getEndPosition())
.append(FIELD_SEPARATOR)
- .append(highlightingRule.getTextType())
+ .append(highlightingRule.getTextType().cssClass())
.append(RULE_SEPARATOR);
}
diff --git a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilder.java b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilder.java
index 792cfb2eb3a..aba6bd66029 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilder.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilder.java
@@ -22,6 +22,7 @@ package org.sonar.batch.highlighting;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.collect.Ordering;
import org.elasticsearch.common.collect.Sets;
+import org.sonar.api.batch.sensor.highlighting.HighlightingBuilder;
import javax.annotation.Nullable;
@@ -51,7 +52,7 @@ public class SyntaxHighlightingDataBuilder {
return syntaxHighlightingRuleSet;
}
- public SyntaxHighlightingDataBuilder registerHighlightingRule(int startOffset, int endOffset, String typeOfText) {
+ public SyntaxHighlightingDataBuilder registerHighlightingRule(int startOffset, int endOffset, HighlightingBuilder.TypeOfText typeOfText) {
SyntaxHighlightingRule syntaxHighlightingRule = SyntaxHighlightingRule.create(startOffset, endOffset,
typeOfText);
this.syntaxHighlightingRuleSet.add(syntaxHighlightingRule);
diff --git a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRule.java b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRule.java
index e6faa7651b4..9ccf5758557 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRule.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRule.java
@@ -19,21 +19,23 @@
*/
package org.sonar.batch.highlighting;
+import org.sonar.api.batch.sensor.highlighting.HighlightingBuilder;
+
import java.io.Serializable;
public class SyntaxHighlightingRule implements Serializable {
private final int startPosition;
private final int endPosition;
- private final String textType;
+ private final HighlightingBuilder.TypeOfText textType;
- private SyntaxHighlightingRule(int startPosition, int endPosition, String textType) {
+ private SyntaxHighlightingRule(int startPosition, int endPosition, HighlightingBuilder.TypeOfText textType) {
this.startPosition = startPosition;
this.endPosition = endPosition;
this.textType = textType;
}
- public static SyntaxHighlightingRule create(int startPosition, int endPosition, String textType) {
+ public static SyntaxHighlightingRule create(int startPosition, int endPosition, HighlightingBuilder.TypeOfText textType) {
return new SyntaxHighlightingRule(startPosition, endPosition, textType);
}
@@ -45,7 +47,7 @@ public class SyntaxHighlightingRule implements Serializable {
return endPosition;
}
- public String getTextType() {
+ public HighlightingBuilder.TypeOfText getTextType() {
return textType;
}
}
diff --git a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRuleValueCoder.java b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRuleValueCoder.java
index e56ee8f0d13..4cc9ea53ab8 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRuleValueCoder.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/highlighting/SyntaxHighlightingRuleValueCoder.java
@@ -22,6 +22,7 @@ package org.sonar.batch.highlighting;
import com.persistit.Value;
import com.persistit.encoding.CoderContext;
import com.persistit.encoding.ValueCoder;
+import org.sonar.api.batch.sensor.highlighting.HighlightingBuilder;
class SyntaxHighlightingRuleValueCoder implements ValueCoder {
@@ -30,14 +31,14 @@ class SyntaxHighlightingRuleValueCoder implements ValueCoder {
SyntaxHighlightingRule rule = (SyntaxHighlightingRule) object;
value.put(rule.getStartPosition());
value.put(rule.getEndPosition());
- value.put(rule.getTextType());
+ value.put(rule.getTextType().ordinal());
}
@Override
public Object get(Value value, Class clazz, CoderContext context) {
int startPosition = value.getInt();
int endPosition = value.getInt();
- String type = value.getString();
+ HighlightingBuilder.TypeOfText type = HighlightingBuilder.TypeOfText.values()[value.getInt()];
return SyntaxHighlightingRule.create(startPosition, endPosition, type);
}
}
diff --git a/sonar-batch/src/main/java/org/sonar/batch/mediumtest/BatchMediumTester.java b/sonar-batch/src/main/java/org/sonar/batch/mediumtest/BatchMediumTester.java
index 92cb3a3ffbb..2905cc6b0d7 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/mediumtest/BatchMediumTester.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/mediumtest/BatchMediumTester.java
@@ -287,21 +287,22 @@ public class BatchMediumTester {
}
/**
- * Get highlighting type at a given position in an inputfile
+ * Get highlighting types at a given position in an inputfile
* @param charIndex 0-based offset in file
*/
@CheckForNull
- public HighlightingBuilder.TypeOfText highlightingTypeFor(InputFile file, int charIndex) {
+ public List<HighlightingBuilder.TypeOfText> highlightingTypeFor(InputFile file, int charIndex) {
SyntaxHighlightingData syntaxHighlightingData = highlightingPerFile.get(file);
if (syntaxHighlightingData == null) {
return null;
}
+ List<HighlightingBuilder.TypeOfText> result = new ArrayList<HighlightingBuilder.TypeOfText>();
for (SyntaxHighlightingRule sortedRule : syntaxHighlightingData.syntaxHighlightingRuleSet()) {
if (sortedRule.getStartPosition() <= charIndex && sortedRule.getEndPosition() > charIndex) {
- return HighlightingBuilder.TypeOfText.forCssClass(sortedRule.getTextType());
+ result.add(sortedRule.getTextType());
}
}
- return null;
+ return result;
}
/**
diff --git a/sonar-batch/src/main/java/org/sonar/batch/source/DefaultHighlightable.java b/sonar-batch/src/main/java/org/sonar/batch/source/DefaultHighlightable.java
index 5b15a3abcd8..b290c9a0dc9 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/source/DefaultHighlightable.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/source/DefaultHighlightable.java
@@ -19,6 +19,7 @@
*/
package org.sonar.batch.source;
+import org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText;
import org.sonar.api.component.Component;
import org.sonar.api.source.Highlightable;
import org.sonar.batch.highlighting.SyntaxHighlightingDataBuilder;
@@ -70,7 +71,8 @@ public class DefaultHighlightable implements Highlightable {
@Override
public HighlightingBuilder highlight(int startOffset, int endOffset, String typeOfText) {
- builder.registerHighlightingRule(startOffset, endOffset, typeOfText);
+ TypeOfText type = org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.forCssClass(typeOfText);
+ builder.registerHighlightingRule(startOffset, endOffset, type);
return this;
}
diff --git a/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilderTest.java b/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilderTest.java
index e511bc388de..4b192a47731 100644
--- a/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilderTest.java
+++ b/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataBuilderTest.java
@@ -27,6 +27,9 @@ import org.junit.rules.ExpectedException;
import java.util.Collection;
import static org.fest.assertions.Assertions.assertThat;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.CLASSIC_COMMENT;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.CPP_DOC;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.KEYWORD;
public class SyntaxHighlightingDataBuilderTest {
@@ -39,12 +42,12 @@ public class SyntaxHighlightingDataBuilderTest {
public void setUpSampleRules() {
SyntaxHighlightingDataBuilder highlightingDataBuilder = new SyntaxHighlightingDataBuilder();
- highlightingDataBuilder.registerHighlightingRule(0, 10, "cd");
- highlightingDataBuilder.registerHighlightingRule(10, 12, "k");
- highlightingDataBuilder.registerHighlightingRule(24, 38, "k");
- highlightingDataBuilder.registerHighlightingRule(42, 50, "k");
- highlightingDataBuilder.registerHighlightingRule(24, 65, "cppd");
- highlightingDataBuilder.registerHighlightingRule(12, 20, "cd");
+ highlightingDataBuilder.registerHighlightingRule(0, 10, CLASSIC_COMMENT);
+ highlightingDataBuilder.registerHighlightingRule(10, 12, KEYWORD);
+ highlightingDataBuilder.registerHighlightingRule(24, 38, KEYWORD);
+ highlightingDataBuilder.registerHighlightingRule(42, 50, KEYWORD);
+ highlightingDataBuilder.registerHighlightingRule(24, 65, CPP_DOC);
+ highlightingDataBuilder.registerHighlightingRule(12, 20, CLASSIC_COMMENT);
highlightingRules = highlightingDataBuilder.getSyntaxHighlightingRuleSet();
}
@@ -58,14 +61,14 @@ public class SyntaxHighlightingDataBuilderTest {
public void should_order_by_start_then_end_offset() throws Exception {
assertThat(highlightingRules).onProperty("startPosition").containsOnly(0, 10, 12, 24, 24, 42);
assertThat(highlightingRules).onProperty("endPosition").containsOnly(10, 12, 20, 38, 65, 50);
- assertThat(highlightingRules).onProperty("textType").containsOnly("cd", "k", "cd", "k", "cppd", "k");
+ assertThat(highlightingRules).onProperty("textType").containsOnly(CLASSIC_COMMENT, KEYWORD, CLASSIC_COMMENT, KEYWORD, CPP_DOC, KEYWORD);
}
@Test
public void should_suport_overlapping() throws Exception {
SyntaxHighlightingDataBuilder builder = new SyntaxHighlightingDataBuilder();
- builder.registerHighlightingRule(0, 15, "k");
- builder.registerHighlightingRule(8, 12, "cppd");
+ builder.registerHighlightingRule(0, 15, KEYWORD);
+ builder.registerHighlightingRule(8, 12, CPP_DOC);
builder.build();
}
@@ -75,8 +78,8 @@ public class SyntaxHighlightingDataBuilderTest {
throwable.expectMessage("Cannot register highlighting rule for characters from 8 to 15 as it overlaps at least one existing rule");
SyntaxHighlightingDataBuilder builder = new SyntaxHighlightingDataBuilder();
- builder.registerHighlightingRule(0, 10, "k");
- builder.registerHighlightingRule(8, 15, "k");
+ builder.registerHighlightingRule(0, 10, KEYWORD);
+ builder.registerHighlightingRule(8, 15, KEYWORD);
builder.build();
}
}
diff --git a/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataTest.java b/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataTest.java
index 59de88ca848..75a78d1becd 100644
--- a/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataTest.java
+++ b/sonar-batch/src/test/java/org/sonar/batch/highlighting/SyntaxHighlightingDataTest.java
@@ -25,6 +25,9 @@ import org.junit.Test;
import java.util.List;
import static org.fest.assertions.Assertions.assertThat;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.CLASSIC_COMMENT;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.CPP_DOC;
+import static org.sonar.api.batch.sensor.highlighting.HighlightingBuilder.TypeOfText.KEYWORD;
public class SyntaxHighlightingDataTest {
@@ -32,12 +35,12 @@ public class SyntaxHighlightingDataTest {
public void should_serialize_rules_to_string() throws Exception {
List<SyntaxHighlightingRule> orderedHighlightingRules = Lists.newArrayList(
- SyntaxHighlightingRule.create(0, 10, "cd"),
- SyntaxHighlightingRule.create(10, 12, "k"),
- SyntaxHighlightingRule.create(12, 20, "cd"),
- SyntaxHighlightingRule.create(24, 38, "k"),
- SyntaxHighlightingRule.create(24, 65, "cppd"),
- SyntaxHighlightingRule.create(42, 50, "k")
+ SyntaxHighlightingRule.create(0, 10, CLASSIC_COMMENT),
+ SyntaxHighlightingRule.create(10, 12, KEYWORD),
+ SyntaxHighlightingRule.create(12, 20, CLASSIC_COMMENT),
+ SyntaxHighlightingRule.create(24, 38, KEYWORD),
+ SyntaxHighlightingRule.create(24, 65, CPP_DOC),
+ SyntaxHighlightingRule.create(42, 50, KEYWORD)
);
String serializedRules = new SyntaxHighlightingData(orderedHighlightingRules).writeString();
diff --git a/sonar-batch/src/test/java/org/sonar/batch/mediumtest/highlighting/HighlightingMediumTest.java b/sonar-batch/src/test/java/org/sonar/batch/mediumtest/highlighting/HighlightingMediumTest.java
index 7e2c71db869..b55a2125cbe 100644
--- a/sonar-batch/src/test/java/org/sonar/batch/mediumtest/highlighting/HighlightingMediumTest.java
+++ b/sonar-batch/src/test/java/org/sonar/batch/mediumtest/highlighting/HighlightingMediumTest.java
@@ -87,10 +87,10 @@ public class HighlightingMediumTest {
.start();
InputFile file = result.inputFiles().get(0);
- assertThat(result.highlightingTypeFor(file, 0)).isEqualTo(HighlightingBuilder.TypeOfText.STRING);
- assertThat(result.highlightingTypeFor(file, 9)).isEqualTo(HighlightingBuilder.TypeOfText.STRING);
- assertThat(result.highlightingTypeFor(file, 10)).isNull();
- assertThat(result.highlightingTypeFor(file, 11)).isEqualTo(HighlightingBuilder.TypeOfText.KEYWORD);
+ assertThat(result.highlightingTypeFor(file, 0)).containsExactly(HighlightingBuilder.TypeOfText.STRING);
+ assertThat(result.highlightingTypeFor(file, 9)).containsExactly(HighlightingBuilder.TypeOfText.STRING);
+ assertThat(result.highlightingTypeFor(file, 10)).isEmpty();
+ assertThat(result.highlightingTypeFor(file, 11)).containsExactly(HighlightingBuilder.TypeOfText.KEYWORD);
}
@@ -126,7 +126,7 @@ public class HighlightingMediumTest {
System.out.println("Duration: " + (System.currentTimeMillis() - start));
InputFile file = result.inputFiles().get(0);
- assertThat(result.highlightingTypeFor(file, 0)).isEqualTo(HighlightingBuilder.TypeOfText.STRING);
+ assertThat(result.highlightingTypeFor(file, 0)).containsExactly(HighlightingBuilder.TypeOfText.STRING);
}