aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/sonar-squid-java-plugin
diff options
context:
space:
mode:
authorsimonbrandhof <simon.brandhof@gmail.com>2011-01-21 14:32:47 +0100
committersimonbrandhof <simon.brandhof@gmail.com>2011-01-21 14:32:47 +0100
commit8015cc71f97f5e049a8120ed54d1fb763f8343f2 (patch)
treea46ef89d8efc75c15800cb75b49143b92e396222 /plugins/sonar-squid-java-plugin
parent08cb4444e0341652a4bf34133485ac405fb1ec50 (diff)
downloadsonarqube-8015cc71f97f5e049a8120ed54d1fb763f8343f2.tar.gz
sonarqube-8015cc71f97f5e049a8120ed54d1fb763f8343f2.zip
SONAR-2130 Publish measures of Java methods on resource tree
Diffstat (limited to 'plugins/sonar-squid-java-plugin')
-rw-r--r--plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/Bridge.java8
-rw-r--r--plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/ResourceIndex.java32
2 files changed, 35 insertions, 5 deletions
diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/Bridge.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/Bridge.java
index 278e9a6cb29..51ab4d0e1f7 100644
--- a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/Bridge.java
+++ b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/Bridge.java
@@ -23,13 +23,15 @@ import org.sonar.api.batch.SensorContext;
import org.sonar.api.checks.CheckFactory;
import org.sonar.api.resources.Project;
import org.sonar.api.resources.Resource;
+import org.sonar.java.api.JavaClass;
import org.sonar.squid.Squid;
+import org.sonar.squid.api.SourceClass;
import org.sonar.squid.api.SourceFile;
import org.sonar.squid.api.SourcePackage;
import org.sonar.squid.api.SourceProject;
/**
- * Pattern visitor : project -> packages -> files
+ * Pattern visitor : project -> packages -> files -> classes
*/
public abstract class Bridge {
@@ -74,4 +76,8 @@ public abstract class Bridge {
public void onFile(SourceFile squidFile, Resource sonarFile) {
}
+
+ public void onClass(SourceClass squidClass, JavaClass sonarClass) {
+
+ }
}
diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/ResourceIndex.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/ResourceIndex.java
index 57134b8ff69..c5d5fa3c55a 100644
--- a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/ResourceIndex.java
+++ b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/ResourceIndex.java
@@ -25,10 +25,9 @@ import org.sonar.api.resources.JavaFile;
import org.sonar.api.resources.JavaPackage;
import org.sonar.api.resources.Project;
import org.sonar.api.resources.Resource;
+import org.sonar.java.api.JavaClass;
import org.sonar.squid.Squid;
-import org.sonar.squid.api.SourceCode;
-import org.sonar.squid.api.SourceFile;
-import org.sonar.squid.api.SourcePackage;
+import org.sonar.squid.api.*;
import org.sonar.squid.indexer.QueryByType;
import java.util.Collection;
@@ -40,6 +39,8 @@ public final class ResourceIndex extends HashMap<SourceCode, Resource> {
loadSquidProject(squid, project);
loadSquidPackages(squid, context);
loadSquidFiles(squid, context);
+ loadSquidClasses(squid, context);
+// loadSquidMethods(squid, context);
return this;
}
@@ -51,7 +52,7 @@ public final class ResourceIndex extends HashMap<SourceCode, Resource> {
Collection<SourceCode> packages = squid.search(new QueryByType(SourcePackage.class));
for (SourceCode squidPackage : packages) {
JavaPackage sonarPackage = SquidUtils.convertJavaPackageKeyFromSquidFormat(squidPackage.getKey());
- context.saveResource(sonarPackage);
+ context.index(sonarPackage);
put(squidPackage, context.getResource(sonarPackage)); // resource is reloaded to get the id
}
}
@@ -65,4 +66,27 @@ public final class ResourceIndex extends HashMap<SourceCode, Resource> {
}
}
+ private void loadSquidClasses(Squid squid, SensorContext context) {
+ Collection<SourceCode> classes = squid.search(new QueryByType(SourceClass.class));
+ for (SourceCode squidClass : classes) {
+ JavaFile sonarFile = (JavaFile)get(squidClass.getParent(SourceFile.class));
+ JavaClass sonarClass = new JavaClass.Builder()
+ .setName(squidClass.getKey())
+ .setFromLine(squidClass.getStartAtLine())
+ .setToLine(squidClass.getEndAtLine())
+ .create();
+ context.index(sonarClass, sonarFile);
+ put(squidClass, context.getResource(sonarClass)); // resource is reloaded to get the id
+ }
+ }
+
+ private void loadSquidMethods(Squid squid, SensorContext context) {
+ Collection<SourceCode> methods = squid.search(new QueryByType(SourceMethod.class));
+ for (SourceCode squidMethod : methods) {
+ JavaClass sonarClass = (JavaClass)get(squidMethod.getParent(SourceClass.class));
+ //context.index(new JavaMethod(squidMethod.getKey()), sonarClass);
+ //put(squidMethod, context.getResource(sonarClass)); // resource is reloaded to get the id
+ }
+ }
+
}