rignore 0.7.1


pip install rignore

  Latest version

Released: Oct 15, 2025

Project Links

Meta
Author: Patrick Arminio
Requires Python: >=3.8

Classifiers

Programming Language
  • Rust
  • Python :: Implementation :: CPython
  • Python :: Implementation :: PyPy

rignore ๐Ÿš€๐Ÿ

rignore is a Python module that provides a high-performance, Rust-powered file system traversal functionality. It wraps the Rust ignore crate using PyO3, offering an efficient way to walk through directories while respecting various ignore rules.

โœจ Features

  • ๐Ÿš€ Fast directory traversal powered by Rust
  • ๐Ÿ™ˆ Respects .gitignore rules
  • ๐Ÿ› ๏ธ Customizable ignore patterns
  • ๐Ÿ’พ Efficient memory usage
  • ๐Ÿ Easy-to-use Python API

๐Ÿ“ฆ Installation

You can install rignore using pip:

pip install rignore

๐Ÿš€ Usage

The main function provided by rignore is walk, which returns an iterator of file paths:

import rignore

for file_path in rignore.walk("/path/to/directory"):
    print(file_path)

๐Ÿ”ง Advanced Usage

The walk function accepts several optional parameters to customize its behavior:

rignore.walk(
    path,
    ignore_hidden=None,
    read_ignore_files=None,
    read_parents_ignores=None,
    read_git_ignore=None,
    read_global_git_ignore=None,
    read_git_exclude=None,
    require_git=None,
    additional_ignores=None,
    additional_ignore_paths=None,
    overrides=None,
    max_depth=None,
    max_filesize=None,
    follow_links=None,
    case_insensitive=None,
    same_file_system=None,
    filter_entry=None,
)

๐Ÿ“ Parameters

  • path (str): The root directory to start the walk from.
  • ignore_hidden (bool, optional): Whether to ignore hidden files and directories.
  • read_ignore_files (bool, optional): Whether to read .ignore files.
  • read_parents_ignores (bool, optional): Whether to read ignore files from parent directories.
  • read_git_ignore (bool, optional): Whether to respect .gitignore files.
  • read_global_git_ignore (bool, optional): Whether to respect global Git ignore rules.
  • read_git_exclude (bool, optional): Whether to respect Git exclude files.
  • require_git (bool, optional): Whether to require the directory to be a Git repository.
  • additional_ignores (List[str], optional): Additional ignore patterns to apply.
  • additional_ignore_paths (List[str], optional): Additional ignore file paths to read.
  • overrides (List[str], optional): Override globs with the same semantics as gitignore. Globs provided here are treated as whitelist matches, meaning only files matching these patterns will be included. Use ! at the beginning of a glob to exclude files (e.g., ["*.txt", ".env.example", "!secret.txt"] will include all .txt files and .env.example, but exclude secret.txt).
  • max_depth (int, optional): Maximum depth to traverse.
  • max_filesize (int, optional): Maximum file size to consider (in bytes).
  • follow_links (bool, optional): Whether to follow symbolic links.
  • case_insensitive (bool, optional): Whether to use case-insensitive matching for ignore patterns.
  • same_file_system (bool, optional): Whether to stay on the same file system.
  • filter_entry (Callable[[str, bool], optional): Custom filter function to exclude entries.

โšก Performance

rignore leverages the power of Rust to provide high-performance directory traversal. It's significantly faster than pure Python implementations, especially for large directory structures.

๐Ÿค Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ™ Acknowledgements

  • ignore - The Rust crate that powers this project
  • PyO3 - The library used to create Python bindings for Rust code

Wheel compatibility matrix

Platform CPython 3.8 CPython 3.9 CPython 3.10 CPython 3.11 CPython 3.12 CPython 3.13 CPython 3.14 CPython (additional flags: t) 3.13 PyPy 3.9 (pp73) PyPy 3.10 (pp73) PyPy 3.11 (pp73)
macosx_10_12_x86_64
macosx_11_0_arm64
manylinux1_i686
manylinux2014_aarch64
manylinux2014_armv7l
manylinux2014_ppc64le
manylinux2014_s390x
manylinux2014_x86_64
manylinux_2_17_aarch64
manylinux_2_17_armv7l
manylinux_2_17_ppc64le
manylinux_2_17_s390x
manylinux_2_17_x86_64
manylinux_2_5_i686
musllinux_1_2_aarch64
musllinux_1_2_armv7l
musllinux_1_2_i686
musllinux_1_2_x86_64
win32
win_amd64
win_arm64

Files in release

rignore-0.7.1-cp310-cp310-macosx_10_12_x86_64.whl (864.5KiB)
rignore-0.7.1-cp310-cp310-macosx_11_0_arm64.whl (798.9KiB)
rignore-0.7.1-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (872.8KiB)
rignore-0.7.1-cp310-cp310-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.3KiB)
rignore-0.7.1-cp310-cp310-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp310-cp310-manylinux_2_17_s390x.manylinux2014_s390x.whl (916.0KiB)
rignore-0.7.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (930.1KiB)
rignore-0.7.1-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.whl (955.1KiB)
rignore-0.7.1-cp310-cp310-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp310-cp310-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp310-cp310-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp310-cp310-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp310-cp310-win32.whl (621.6KiB)
rignore-0.7.1-cp310-cp310-win_amd64.whl (701.1KiB)
rignore-0.7.1-cp311-cp311-macosx_10_12_x86_64.whl (864.2KiB)
rignore-0.7.1-cp311-cp311-macosx_11_0_arm64.whl (798.9KiB)
rignore-0.7.1-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (872.7KiB)
rignore-0.7.1-cp311-cp311-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.2KiB)
rignore-0.7.1-cp311-cp311-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp311-cp311-manylinux_2_17_s390x.manylinux2014_s390x.whl (916.2KiB)
rignore-0.7.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (930.0KiB)
rignore-0.7.1-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.whl (955.2KiB)
rignore-0.7.1-cp311-cp311-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp311-cp311-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp311-cp311-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp311-cp311-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp311-cp311-win32.whl (621.3KiB)
rignore-0.7.1-cp311-cp311-win_amd64.whl (701.2KiB)
rignore-0.7.1-cp311-cp311-win_arm64.whl (634.4KiB)
rignore-0.7.1-cp312-cp312-macosx_10_12_x86_64.whl (861.4KiB)
rignore-0.7.1-cp312-cp312-macosx_11_0_arm64.whl (795.6KiB)
rignore-0.7.1-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (872.8KiB)
rignore-0.7.1-cp312-cp312-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.3KiB)
rignore-0.7.1-cp312-cp312-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp312-cp312-manylinux_2_17_s390x.manylinux2014_s390x.whl (916.0KiB)
rignore-0.7.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (929.6KiB)
rignore-0.7.1-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.whl (955.0KiB)
rignore-0.7.1-cp312-cp312-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp312-cp312-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp312-cp312-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp312-cp312-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp312-cp312-win32.whl (620.4KiB)
rignore-0.7.1-cp312-cp312-win_amd64.whl (701.1KiB)
rignore-0.7.1-cp312-cp312-win_arm64.whl (632.8KiB)
rignore-0.7.1-cp313-cp313-macosx_10_12_x86_64.whl (861.1KiB)
rignore-0.7.1-cp313-cp313-macosx_11_0_arm64.whl (795.3KiB)
rignore-0.7.1-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (872.5KiB)
rignore-0.7.1-cp313-cp313-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (846.9KiB)
rignore-0.7.1-cp313-cp313-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp313-cp313-manylinux_2_17_s390x.manylinux2014_s390x.whl (915.8KiB)
rignore-0.7.1-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (929.5KiB)
rignore-0.7.1-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.whl (954.7KiB)
rignore-0.7.1-cp313-cp313-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp313-cp313-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp313-cp313-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp313-cp313-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp313-cp313-win32.whl (620.4KiB)
rignore-0.7.1-cp313-cp313-win_amd64.whl (701.2KiB)
rignore-0.7.1-cp313-cp313-win_arm64.whl (632.6KiB)
rignore-0.7.1-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (872.0KiB)
rignore-0.7.1-cp313-cp313t-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.0KiB)
rignore-0.7.1-cp313-cp313t-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp313-cp313t-manylinux_2_17_s390x.manylinux2014_s390x.whl (916.0KiB)
rignore-0.7.1-cp313-cp313t-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp313-cp313t-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp313-cp313t-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp313-cp313t-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp314-cp314-macosx_10_12_x86_64.whl (859.9KiB)
rignore-0.7.1-cp314-cp314-macosx_11_0_arm64.whl (795.6KiB)
rignore-0.7.1-cp314-cp314-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (929.0KiB)
rignore-0.7.1-cp314-cp314-manylinux_2_5_i686.manylinux1_i686.whl (954.6KiB)
rignore-0.7.1-cp314-cp314-win32.whl (620.7KiB)
rignore-0.7.1-cp314-cp314-win_amd64.whl (701.1KiB)
rignore-0.7.1-cp314-cp314-win_arm64.whl (632.6KiB)
rignore-0.7.1-cp38-cp38-macosx_10_12_x86_64.whl (865.1KiB)
rignore-0.7.1-cp38-cp38-macosx_11_0_arm64.whl (800.0KiB)
rignore-0.7.1-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (874.0KiB)
rignore-0.7.1-cp38-cp38-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.7KiB)
rignore-0.7.1-cp38-cp38-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp38-cp38-manylinux_2_17_s390x.manylinux2014_s390x.whl (917.0KiB)
rignore-0.7.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (930.9KiB)
rignore-0.7.1-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.whl (956.2KiB)
rignore-0.7.1-cp38-cp38-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp38-cp38-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp38-cp38-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp38-cp38-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp38-cp38-win32.whl (623.3KiB)
rignore-0.7.1-cp38-cp38-win_amd64.whl (702.2KiB)
rignore-0.7.1-cp39-cp39-macosx_10_12_x86_64.whl (866.1KiB)
rignore-0.7.1-cp39-cp39-macosx_11_0_arm64.whl (800.8KiB)
rignore-0.7.1-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (874.2KiB)
rignore-0.7.1-cp39-cp39-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (848.2KiB)
rignore-0.7.1-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl (917.4KiB)
rignore-0.7.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (931.0KiB)
rignore-0.7.1-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.whl (957.1KiB)
rignore-0.7.1-cp39-cp39-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-cp39-cp39-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-cp39-cp39-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-cp39-cp39-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-cp39-cp39-win32.whl (623.3KiB)
rignore-0.7.1-cp39-cp39-win_amd64.whl (702.6KiB)
rignore-0.7.1-pp310-pypy310_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (875.3KiB)
rignore-0.7.1-pp310-pypy310_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (848.5KiB)
rignore-0.7.1-pp310-pypy310_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-pp310-pypy310_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (918.1KiB)
rignore-0.7.1-pp310-pypy310_pp73-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-pp310-pypy310_pp73-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-pp310-pypy310_pp73-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-pp310-pypy310_pp73-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (873.8KiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (847.9KiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (917.5KiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (930.6KiB)
rignore-0.7.1-pp311-pypy311_pp73-manylinux_2_5_i686.manylinux1_i686.whl (956.3KiB)
rignore-0.7.1-pp311-pypy311_pp73-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-pp311-pypy311_pp73-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-pp311-pypy311_pp73-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-pp311-pypy311_pp73-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (875.3KiB)
rignore-0.7.1-pp39-pypy39_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (849.2KiB)
rignore-0.7.1-pp39-pypy39_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.1MiB)
rignore-0.7.1-pp39-pypy39_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (918.1KiB)
rignore-0.7.1-pp39-pypy39_pp73-musllinux_1_2_aarch64.whl (1.0MiB)
rignore-0.7.1-pp39-pypy39_pp73-musllinux_1_2_armv7l.whl (1.1MiB)
rignore-0.7.1-pp39-pypy39_pp73-musllinux_1_2_i686.whl (1.1MiB)
rignore-0.7.1-pp39-pypy39_pp73-musllinux_1_2_x86_64.whl (1.1MiB)
rignore-0.7.1.tar.gz (15.1KiB)
No dependencies