FilesFinder

Find files matching patterns while respecting .gitignore

Crates.io

  1. About
  2. Installation
  3. Examples
  4. GitHub Action
  5. CHANGELOG
  6. Contributing

About

FilesFinder (FF) is a command-line tool that aims to search for files within a given repository. As such, it respects your .gitignore files and exclude the same files from the output.

FF is a fast and simpler-to-use alternative to other tools such as find from Findutils.

NOTE: FF is not necessarily faster than find (or else), but speed is plays an important in its development and you can be sure that opting to ff will not decrease performance by much.

Installation

You can install the latest released version with cargo:

```bash

cargo install filesfinder ```

After that, FilesFinder can be used via the ff alias.

```text USAGE: ff [OPTIONS] ... ff [OPTIONS] [OPTIONS] ...

ARGS: ... A pattern to match against each file.

OPTIONS: -g, -G Parse pattern as a glob expression. [default behavior]

-r, -R
        Parse pattern as a regular expression.

-i, -I
        Matching files will be included in the output.
        [default behavior]

-e, -E
        Matching files will be excluded from the output.

    --dir <PATH>
        Files will be searched in the directory specified by the PATH.
        [default: '.']

    --show-hidden
        Allow to show hidden files.

    --no-gitignore
        Ignore gitignore files.

-h, --help
        Print help information.

-V, --version
        Print version information.

NOTES: - Capitalized options (.e.g., '-G') apply to all subsequent patterns. E.g.: 'ff -g ".rs" -g ".md"' is equivalent to 'ff -G ".rs" ".md"'. You can always unset a flag by overriding it.

-   Options can be grouped under the same '-'.
    E.g.: 'ff -e -g "*.rs"' is equivalent to 'ff -eg "*.rs"'.

-   File exclusion is performed after file inclusion.

-   For performance reasons, prefer to use more general patterns first,
    and more specific ones at the end.
    E.g.: 'ff "*.md" "Cargo.toml"' is faster but equivalent to 'ff "Cargo.toml" "*.md"'.

```

Examples

```bash

ff "*.rs"

List all files with '.rs' extension

ff ".rs" -e "src/*.rs"

List all files with 'rs' extension except those in the 'src' folder

ff -r ".*.md"

List all files with 'md' extension, using regular expression

ff -Re "..md" "."

List all files except those with 'md' extension, using regular expression

```

GitHub Action

A major application to FF is to be used within repositories. Therefore, you can also use the FilesFinder` GitHub Action withing your projects.

```yml

Your action in .github/workflows

Contributing

Contributions are more than welcome!

Future features