All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.api.batch.fs.FilePredicates Maven / Gradle / Ivy

There is a newer version: 11.0.0.2664
Show newest version
/*
 * Sonar Plugin API
 * Copyright (C) 2009-2024 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.fs;

import java.io.File;
import java.net.URI;
import java.util.Collection;

/**
 * Factory of {@link org.sonar.api.batch.fs.FilePredicate}
 *
 * @since 4.2
 */
public interface FilePredicates {
  /**
   * Predicate that always evaluates to true
   */
  FilePredicate all();

  /**
   * Predicate that always evaluates to false
   */
  FilePredicate none();

  /**
   * Predicate that find file by its absolute path. The parameter
   * accepts forward/back slashes as separator and non-normalized values
   * (/path/to/../foo.txt is same as /path/foo.txt).
   * 

* Warning - may not be supported in SonarLint */ FilePredicate hasAbsolutePath(String s); /** * Predicate that gets a file by its relative path. The parameter * accepts forward/back slashes as separator and non-normalized values * (foo/../bar.txt is same as bar.txt). It must * not be null. *

* Warning - may not be supported in SonarLint */ FilePredicate hasRelativePath(String s); /** * Predicate that matches files by filename, in any directory. * For example, the parameter Foo.java will match both * some/path/Foo.java and other/path/Foo.java. * The parameter must match exactly, no patterns are allowed, * and it must not be null. * * @since 6.3 */ FilePredicate hasFilename(String s); /** * Predicate that matches files by extension (case insensitive). * For example, the parameter java will match * some/path/Foo.java and other/path/Foo.JAVA * but not some/path/Foo.js. * The parameter must not be null. * * @since 6.3 */ FilePredicate hasExtension(String s); /** * Predicate that gets a file by its {@link InputFile#uri()}. * * @since 6.6 */ FilePredicate hasURI(URI uri); /** * Predicate that gets the files which "path" matches a wildcard pattern. *

* The path is the path part of the {@link InputFile#uri()}. Pattern is case-sensitive, except for file extension. *

* Supported wildcards are * and **, but not ?. *
* Examples: *

    *
  • **/*Foo.java matches Foo.java, src/Foo.java and src/java/SuperFoo.java
  • *
  • **/*Foo*.java matches src/Foo.java, src/BarFoo.java, src/FooBar.java * and src/BarFooBaz.java
  • *
  • **/*FOO.JAVA matches FOO.java and FOO.JAVA but not Foo.java
  • *
*/ 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)} *

* Warning - may not be supported in SonarLint */ FilePredicate hasPath(String s); /** * Warning - may not be supported in SonarLint */ FilePredicate is(File ioFile); FilePredicate hasLanguage(String language); FilePredicate hasLanguages(Collection languages); FilePredicate hasLanguages(String... languages); FilePredicate hasType(InputFile.Type type); FilePredicate not(FilePredicate p); FilePredicate or(Collection or); FilePredicate or(FilePredicate... or); FilePredicate or(FilePredicate first, FilePredicate second); FilePredicate and(Collection and); FilePredicate and(FilePredicate... and); FilePredicate and(FilePredicate first, FilePredicate second); /** * Look for InputFile having a specific {@link InputFile#status()} * @since 6.6 */ FilePredicate hasStatus(InputFile.Status status); /** * Explicitely look for InputFile having any {@link InputFile#status()} * @since 6.6 */ FilePredicate hasAnyStatus(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy