diff options
author | Evgeny Mandrikov <mandrikov@gmail.com> | 2011-09-08 13:46:01 +0400 |
---|---|---|
committer | Evgeny Mandrikov <mandrikov@gmail.com> | 2011-09-08 15:50:25 +0400 |
commit | ae6cd424cdfce583739a61ffc387aa8efc04cb2d (patch) | |
tree | 8aaa52524762c058ee94253ad6ffbde7ff55978a /plugins/sonar-cpd-plugin | |
parent | 00398c07d64cea029383a594d1b42ed737831515 (diff) | |
download | sonarqube-ae6cd424cdfce583739a61ffc387aa8efc04cb2d.tar.gz sonarqube-ae6cd424cdfce583739a61ffc387aa8efc04cb2d.zip |
SONAR-1091 Use correct encoding during detection of duplications
Diffstat (limited to 'plugins/sonar-cpd-plugin')
-rw-r--r-- | plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java index a81c754ba97..8376e0fb1cd 100644 --- a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java +++ b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java @@ -19,7 +19,10 @@ */ package org.sonar.plugins.cpd; -import java.io.File; +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.InputStreamReader; +import java.io.Reader; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; @@ -28,6 +31,7 @@ import java.util.HashSet; import java.util.List; import java.util.Set; +import org.apache.commons.io.IOUtils; import org.apache.commons.lang.StringUtils; import org.sonar.api.CoreProperties; import org.sonar.api.batch.SensorContext; @@ -42,6 +46,7 @@ import org.sonar.api.resources.Language; import org.sonar.api.resources.Project; import org.sonar.api.resources.Resource; import org.sonar.api.utils.Logs; +import org.sonar.api.utils.SonarException; import org.sonar.batch.index.ResourcePersister; import org.sonar.duplications.block.Block; import org.sonar.duplications.block.BlockChunker; @@ -53,7 +58,6 @@ import org.sonar.duplications.java.JavaTokenProducer; import org.sonar.duplications.statement.Statement; import org.sonar.duplications.statement.StatementChunker; import org.sonar.duplications.token.TokenChunker; -import org.sonar.duplications.token.TokenQueue; import org.sonar.plugins.cpd.index.DbDuplicationsIndex; import org.sonar.plugins.cpd.index.SonarDuplicationsIndex; @@ -123,9 +127,18 @@ public class SonarEngine extends CpdEngine { Resource resource = getResource(inputFile); String resourceKey = getFullKey(project, resource); - File file = inputFile.getFile(); - TokenQueue tokenQueue = tokenChunker.chunk(file); - List<Statement> statements = statementChunker.chunk(tokenQueue); + List<Statement> statements; + + Reader reader = null; + try { + reader = new InputStreamReader(new FileInputStream(inputFile.getFile()), project.getFileSystem().getSourceCharset()); + statements = statementChunker.chunk(tokenChunker.chunk(reader)); + } catch (FileNotFoundException e) { + throw new SonarException(e); + } finally { + IOUtils.closeQuietly(reader); + } + List<Block> blocks = blockChunker.chunk(resourceKey, statements); index.insert(resource, blocks); } |