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.0.9.tar.gz
(11.8 kB
view details)
File details
Details for the file gitignorefile-1.0.9.tar.gz
.
File metadata
- Download URL: gitignorefile-1.0.9.tar.gz
- Upload date:
- Size: 11.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 546ab6135768c564f01d1ab90909c0b45384cdbabe4cc31be10e87b12138f161 |
|
MD5 | 36dc30e2907e8f6380f18e89bddad969 |
|
BLAKE2b-256 | 49f9d58c25124d82a3c92ca6aff8ac1e7dd54bad0b75746125d5676a2e22bf8e |