A spec-compliant `.gitignore` parser for Python
Project description
gitignorefile
A spec-compliant .gitignore
parser for Python.
Installation
pip3 install gitignorefile
Usage
gitignorefile.parse()
Parses single .gitignore
file. Suppose /home/michael/project/.gitignore
contains the following:
__pycache__/
*.py[cod]
Then:
import gitignorefile
matches = gitignorefile.parse("/home/michael/project/.gitignore")
matches("/home/michael/project/main.py") # False
matches("/home/michael/project/main.pyc") # True
matches("/home/michael/project/dir/main.pyc") # True
matches("/home/michael/project/__pycache__") # True
gitignorefile.ignore()
shutil.copytree()
ignore function which checks if file is ignored by any .gitignore
in the directory tree.
Example:
import shutil
import gitignorefile
shutil.copytree("/source", "/destination", ignore=gitignorefile.ignore())
gitignorefile.ignored()
Checks if file is ignored by any .gitignore
in the directory tree.
import gitignorefile
gitignorefile.ignored("/home/michael/project/main.py") # False
gitignorefile.Cache
Caches .gitignore
rules discovered in the directory tree.
import gitignorefile
matches = gitignorefile.Cache()
matches("/home/michael/project/main.py") # False
matches("/home/michael/project/main.pyc") # True
matches("/home/michael/project/dir/main.pyc") # True
matches("/home/michael/project/__pycache__") # True
Custom ignore file sources
You could override files, that will be used to fetch ignore rules. Default value is [".gitignore", ".git/info/exclude"]
.
import gitignorefile
matches = gitignorefile.Cache(ignore_names=[".mylovelytoolignore"])
matches("/home/michael/project/main.py") # False
matches("/home/michael/project/main.pyc") # True
matches("/home/michael/project/dir/main.pyc") # True
matches("/home/michael/project/__pycache__") # True
Credits
- https://github.com/snark/ignorance by Steve Cook
- https://github.com/mherrmann/gitignore_parser by Michael Herrmann
- https://github.com/bitranox/igittigitt by Robert Nowotny
- https://github.com/cpburnz/python-path-specification by Caleb Burns
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
gitignorefile-1.1.1.tar.gz
(12.1 kB
view details)
File details
Details for the file gitignorefile-1.1.1.tar.gz
.
File metadata
- Download URL: gitignorefile-1.1.1.tar.gz
- Upload date:
- Size: 12.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dd692bde6988e615d60dc9be83aea480087a84a6c73bc058bf33f5153f224582 |
|
MD5 | 27c5eb07f23de92c70f872f7f3287ae2 |
|
BLAKE2b-256 | e85cb28e272656cea09126f400e789eb234dc27feb5a674bf6555ac7bbde4fc5 |