ff — Find Files

Build Status Version info

ff: Just my own fork of [fd] with many incompatible changes. (unstable)

Installation

cargo install ff-find

or when SIMD acceleration is possible:

cargo install --features simd-accel ff-find

Usage

ff lets you search for files and directories with a glob pattern.

bash ff $HOME '*.txt'

More power (and danger) come with the --regex switch to use regex patterns.

bash ff --regex $HOME '\.txt$'

Unicode support:

```bash ff . '?' # doesn't match filename π ff --unicode . '?' # matches filename π

ff --regex . '^.$' # doesn't match filename π ff --regex --unicode . '^.$' # matches filename π ```

This is because the pattern matches byte strings by default.

Help

``` USAGE: ff [OPTIONS] [ [PATTERN]]

OPTIONS: -g, --glob Match the whole file path with a glob pattern. This is the default behavior.

-r, --regex
        Match the whole file path with a regex pattern. [default: glob]

-u, --unicode
        Turn on Unicode support for search patterns. Character classes are
        not limited to ASCII. Only valid UTF-8 byte sequences can be matched
        by the search pattern.

-i, --ignore-case
        Perform a case-insensitive search. This overrides --case-sensitive.

-s, --case-sensitive
        Perform a case-sensitive search. This is the default behavior.

-p, --full-path
        Match the absolute path instead of the filename or directory name.

-L, --follow
        Follow symlinks and traverse the symlinked directories.

-M, --mount
        Do not descend into directories on other filesystems, as a symlink
        may point to a directory on another filesystem.

-0, --print0
        Each search result is terminated with NUL instead of LF when
        printed.

-A, --absolute-path
        Relative paths for output are transformed into absolute paths.

-S, --sort-path
        The search results will be sorted by pathname before output. Sort by
        lexicographically comparing the byte strings of path components (not
        comparing the whole pathnames directly).

-a, --all
        All files and directories are searched. By default, files and
        directories of which the names start with a dot "." are ignored in
        the search. Files ignored by patterns in .(git)ignore files are
        still excluded.

-I, --no-ignore
        Show search results from files and directories that would otherwise
        be ignored by .(git)ignore files.

-m, --multiplex
        Multiplex stdin of this program so that every executed command
        shares the same input. Interactive input is disabled by caching,
        even if the commands run sequentially.

-t, --type <filetype>
        Filter the search by type: [default: no filter]
            directory or d: directories
                 file or f: regular files
              symlink or l: symbolic links
           executable or x: executable files

-d, --max-depth <number>
        Limit the directory traversal to a given depth.

-c, --color <when>
        Declare when to use color for the pattern match output:
              auto: use colors for interactive console [default]
             never: do not use colorized output
            always: always use colorized output

-j, --threads <number>
        The number of threads to use for searching and command execution.
        0 means [default: number of available CPU cores]

    --max-buffer-time <milliseconds>
        The amount of time (in milliseconds) for the search results to be
        buffered and sorted before streaming.

-x, --exec <program [argument]... [;]>
        Run the given command for each search result, which can be
        represented by a pair of braces {} in the command. If the command
        does not contain any {}, then a {} will be appended as an argument
        to the program. A single semicolon ; will terminate the argument
        list.
        With --threads=1 commands will run sequentially. When multi
        -threading is enabled and multiplexing is not enabled, commands
        will not receive input from the terminal.

-v, --verbose
        Show warnings about file permissions, loops caused by symlinks, I/O
        errors, invalid file content, etc.

-h, --help
        Prints help information. Use --help for more details.

-V, --version
        Prints version information

ARGS: The directory where the filesystem search is rooted. If omitted, search the current working directory.

<PATTERN>
        The search pattern, a regex or glob pattern. [optional]
        The default values for regex and glob are ^ and * respectively.

```

References

Please note that the nitty-gritty of supported syntax may change in the future. There are still some todos noted in the source code.

License

Copyright (c) 2017 ff developers

Copyright (c) 2017 fd developers

All files in the project are licensed under the [Apache License], Version 2.0 or the [MIT License], at your option.