aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2014-10-06 17:56:45 +0200
committerSimon Brandhof <simon.brandhof@sonarsource.com>2014-10-06 17:56:54 +0200
commit482fa89e9cc3eb7eebd5439ee5b3d044d5fe42c3 (patch)
treec52b079cf1a503ed889576f807ec7152a4c0f0c8
parent5e493e0cacaed07f7413c8a68f1e5b26e8e72d7a (diff)
downloadsonarqube-482fa89e9cc3eb7eebd5439ee5b3d044d5fe42c3.tar.gz
sonarqube-482fa89e9cc3eb7eebd5439ee5b3d044d5fe42c3.zip
Add some javadoc to FilePredicates
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/FilePredicates.java48
1 files changed, 45 insertions, 3 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/FilePredicates.java b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/FilePredicates.java
index 65a2e19d6a5..4dcc80df393 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/FilePredicates.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/FilePredicates.java
@@ -29,33 +29,75 @@ import java.util.Collection;
*/
public interface FilePredicates {
/**
- * Returns a predicate that always evaluates to true
+ * Predicate that always evaluates to true
*/
FilePredicate all();
/**
- * Returns a predicate that always evaluates to false
+ * Predicate that always evaluates to false
*/
FilePredicate none();
/**
+ * Predicate that gets a file by its absolute path. The parameter
+ * accepts forward/back slashes as separator and non-normalized values
+ * (<code>/path/to/../foo.txt</code> is same as <code>/path/foo.txt</code>).
+ * <p/>
* Warning - not efficient because absolute path is not indexed yet.
*/
FilePredicate hasAbsolutePath(String s);
/**
- * TODO document that non-normalized path and Windows-style path are supported
+ * Predicate that gets a file by its relative path. The parameter
+ * accepts forward/back slashes as separator and non-normalized values
+ * (<code>foo/../bar.txt</code> is same as <code>bar.txt</code>). It must
+ * not be <code>null</code>.
*/
FilePredicate hasRelativePath(String s);
+ /**
+ * Predicate that gets the files which relative or absolute path matches a wildcard pattern.
+ * <p/>
+ * If the parameter starts with <code>file:</code>, then absolute path is used, else relative path. Pattern
+ * is case-sensitive, except for file extension.
+ * <p/>
+ * Supported wildcards are <code>&#42;</code> and <code>&#42;&#42;</code>, but not <code>?</code>.
+ * <p/>
+ * Examples:
+ * <ul>
+ * <li><code>&#42;&#42;/&#42;Foo.java</code> matches Foo.java, src/Foo.java and src/java/SuperFoo.java</li>
+ * <li><code>&#42;&#42;/&#42;Foo&#42;.java</code> matches src/Foo.java, src/BarFoo.java, src/FooBar.java
+ * and src/BarFooBaz.java</li>
+ * <li><code>&#42;&#42;/&#42;FOO.JAVA</code> matches FOO.java and FOO.JAVA but not Foo.java</li>
+ * <li><code>file:&#42;&#42;/src/&#42;Foo.java</code> matches /path/to/src/Foo.java on unix and c:\path\to\Foo.java on MSWindows</li>
+ * </ul>
+ */
FilePredicate matchesPathPattern(String inclusionPattern);
+ /**
+ * Predicate that gets the files matching at least one wildcard pattern. No filter is applied when
+ * zero wildcard patterns (similar to {@link #all()}.
+ * @see #matchesPathPattern(String)
+ */
FilePredicate matchesPathPatterns(String[] inclusionPatterns);
+ /**
+ * Predicate that gets the files that do not match the given wildcard pattern.
+ * @see #matchesPathPattern(String)
+ */
FilePredicate doesNotMatchPathPattern(String exclusionPattern);
+ /**
+ * Predicate that gets the files that do not match any of the given wildcard patterns. No filter is applied when
+ * zero wildcard patterns (similar to {@link #all()}.
+ * @see #matchesPathPattern(String)
+ */
FilePredicate doesNotMatchPathPatterns(String[] exclusionPatterns);
+ /**
+ * if the parameter represents an absolute path for the running environment, then
+ * returns {@link #hasAbsolutePath(String)}, else {@link #hasRelativePath(String)}
+ */
FilePredicate hasPath(String s);
FilePredicate is(File ioFile);