diff options
author | BenoƮt Gianinetti <benoit.gianinetti@sonarsource.com> | 2019-01-09 15:36:13 +0100 |
---|---|---|
committer | SonarTech <sonartech@sonarsource.com> | 2019-01-22 20:21:01 +0100 |
commit | d666593ada6756a990e7b50b35e765f45e684703 (patch) | |
tree | 2ecf0238e5c2f42503bf2de3a52e41c9aeb21c92 /sonar-plugin-api/src | |
parent | bb78029124fc2f082a30ba6aa18a84c105a0d80e (diff) | |
download | sonarqube-d666593ada6756a990e7b50b35e765f45e684703.tar.gz sonarqube-d666593ada6756a990e7b50b35e765f45e684703.zip |
SONAR-11620 Add scm based file exclusion method to plugin api
Diffstat (limited to 'sonar-plugin-api/src')
3 files changed, 65 insertions, 0 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/IgnoreCommand.java b/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/IgnoreCommand.java new file mode 100644 index 00000000000..a406595b908 --- /dev/null +++ b/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/IgnoreCommand.java @@ -0,0 +1,55 @@ +/* + * SonarQube + * Copyright (C) 2009-2019 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.api.batch.scm; + +import java.nio.file.Path; +import org.sonar.api.scanner.ScannerSide; + +/** + * @since 7.6 + */ +@ScannerSide +public interface IgnoreCommand { + + /** + * Check if a file is ignored by the scm. + * {@link #init(Path)} must be called before the first call to this method and {@link #clean()} after the last one + * + * @param file Absolute path of a project file + * @return true if the given file is ignored by the scm, false otherwise + */ + boolean isIgnored(Path file); + + /** + * Must be called before the calling {@link #isIgnored(Path)} + * + * It should contains any operation (e.g. building cache) required before handling {@link #isIgnored(Path)} calls. + * + * @param baseDir the root directory of the project + */ + void init(Path baseDir); + + /** + * To be called after the last call to {@link #isIgnored(Path)}. + * + * Cache or any other resources used should be cleared. + */ + void clean(); +} diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/ScmProvider.java b/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/ScmProvider.java index 1ee042001d5..5a354933fac 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/ScmProvider.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/batch/scm/ScmProvider.java @@ -87,6 +87,10 @@ public abstract class ScmProvider { throw new UnsupportedOperationException(formatUnsupportedMessage("Getting relative path from SCM root")); } + public IgnoreCommand ignoreCommand() { + throw new UnsupportedOperationException(formatUnsupportedMessage("Checking for ignored files")); + } + /** * The current revision id of the analyzed code, * for example the SHA1 of the current HEAD in a Git branch. diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/batch/scm/ScmProviderTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/batch/scm/ScmProviderTest.java index 123cb457803..ff18273c885 100644 --- a/sonar-plugin-api/src/test/java/org/sonar/api/batch/scm/ScmProviderTest.java +++ b/sonar-plugin-api/src/test/java/org/sonar/api/batch/scm/ScmProviderTest.java @@ -57,4 +57,10 @@ public class ScmProviderTest { thrown.expect(UnsupportedOperationException.class); provider.revisionId(Paths.get("foo")); } + + @Test + public void default_implementation_does_not_support_ignore() { + thrown.expect(UnsupportedOperationException.class); + provider.ignoreCommand(); + } } |