diff options
Diffstat (limited to 'sonar-batch')
4 files changed, 27 insertions, 14 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystem.java b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystem.java index 73ba970889d..4d29ee9f8ab 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystem.java +++ b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystem.java @@ -94,7 +94,7 @@ public class DefaultModuleFileSystem implements ModuleFileSystem { } boolean isDefaultSourceCharset() { - return settings.hasKey(CoreProperties.ENCODING_PROPERTY); + return !settings.hasKey(CoreProperties.ENCODING_PROPERTY); } public File workingDir() { diff --git a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/ExclusionFilters.java b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/ExclusionFilters.java index 7abfac92823..959b63e28c7 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/ExclusionFilters.java +++ b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/ExclusionFilters.java @@ -91,9 +91,9 @@ public class ExclusionFilters implements FileSystemFilter, ResourceFilter, Batch private boolean isIgnoredFileResource(Resource resource) { PathPattern[] inclusionPatterns = (ResourceUtils.isUnitTestClass(resource) ? testInclusions : sourceInclusions); if (inclusionPatterns.length > 0) { - boolean matchInclusion = false; + boolean matchInclusion = true; for (PathPattern pattern : inclusionPatterns) { - matchInclusion |= pattern.match(resource); + matchInclusion &= (!pattern.supportResource() || pattern.match(resource)); } if (!matchInclusion) { return true; @@ -101,7 +101,7 @@ public class ExclusionFilters implements FileSystemFilter, ResourceFilter, Batch } PathPattern[] exclusionPatterns = (ResourceUtils.isUnitTestClass(resource) ? testExclusions : sourceExclusions); for (PathPattern pattern : exclusionPatterns) { - if (pattern.match(resource)) { + if (pattern.supportResource() && pattern.match(resource)) { return true; } } diff --git a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/PathPattern.java b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/PathPattern.java index 7df5d1c945a..e7614d585b6 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/PathPattern.java +++ b/sonar-batch/src/main/java/org/sonar/batch/scan/filesystem/PathPattern.java @@ -35,17 +35,20 @@ abstract class PathPattern { abstract boolean match(Resource resource); + abstract boolean supportResource(); + static PathPattern create(String s) { - if (StringUtils.startsWithIgnoreCase(s, "file:")) { - return new AbsolutePathPattern(StringUtils.substring(s, "file:".length())); + String trimmed = StringUtils.trim(s); + if (StringUtils.startsWithIgnoreCase(trimmed, "file:")) { + return new AbsolutePathPattern(StringUtils.substring(trimmed, "file:".length())); } - return new RelativePathPattern(s); + return new RelativePathPattern(trimmed); } static PathPattern[] create(String[] s) { PathPattern[] result = new PathPattern[s.length]; for (int i = 0; i < s.length; i++) { - result[i] = PathPattern.create(s[i]); + result[i] = create(s[i]); } return result; } @@ -63,6 +66,10 @@ abstract class PathPattern { return false; } + boolean supportResource() { + return false; + } + @Override public String toString() { return "file:" + pattern.toString(); @@ -82,6 +89,10 @@ abstract class PathPattern { return resource.matchFilePattern(pattern.toString()); } + boolean supportResource() { + return true; + } + @Override public String toString() { return pattern.toString(); diff --git a/sonar-batch/src/test/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystemTest.java b/sonar-batch/src/test/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystemTest.java index afc4009f67b..74aa5bd264a 100644 --- a/sonar-batch/src/test/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystemTest.java +++ b/sonar-batch/src/test/java/org/sonar/batch/scan/filesystem/DefaultModuleFileSystemTest.java @@ -78,19 +78,21 @@ public class DefaultModuleFileSystemTest { .setSettings(new Settings()); assertThat(fileSystem.sourceCharset()).isEqualTo(Charset.defaultCharset()); + assertThat(fileSystem.isDefaultSourceCharset()).isTrue(); } @Test - public void source_encoding_is_set() { - File basedir = temp.newFolder("base"); + public void source_encoding_is_set() { + File basedir = temp.newFolder("base"); Settings settings = new Settings(); settings.setProperty(CoreProperties.ENCODING_PROPERTY, "UTF-8"); DefaultModuleFileSystem fileSystem = new DefaultModuleFileSystem() - .setBaseDir(basedir) - .setSettings(settings); + .setBaseDir(basedir) + .setSettings(settings); - assertThat(fileSystem.sourceCharset()).isEqualTo(Charset.forName("UTF-8")); - } + assertThat(fileSystem.sourceCharset()).isEqualTo(Charset.forName("UTF-8")); + assertThat(fileSystem.isDefaultSourceCharset()).isFalse(); + } @Test public void should_exclude_dirs_starting_with_dot() throws IOException { |