diff options
author | simonbrandhof <simon.brandhof@gmail.com> | 2011-01-21 14:32:47 +0100 |
---|---|---|
committer | simonbrandhof <simon.brandhof@gmail.com> | 2011-01-21 14:32:47 +0100 |
commit | 8015cc71f97f5e049a8120ed54d1fb763f8343f2 (patch) | |
tree | a46ef89d8efc75c15800cb75b49143b92e396222 /plugins/sonar-squid-java-plugin | |
parent | 08cb4444e0341652a4bf34133485ac405fb1ec50 (diff) | |
download | sonarqube-8015cc71f97f5e049a8120ed54d1fb763f8343f2.tar.gz sonarqube-8015cc71f97f5e049a8120ed54d1fb763f8343f2.zip |
SONAR-2130 Publish measures of Java methods on resource tree
Diffstat (limited to 'plugins/sonar-squid-java-plugin')
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 + } + } + } |