Standardize and plan out a file structure!
Project description
Path Schema
pip install pathschema
How to use
from pathschema import validate
schema = 'YOUR SCHEMA HERE'
path_to_validate = './path'
with open('path/to/schema.pathschema', 'r') as f:
schema = f.read()
result = validate(path_to_validate, schema)
if(result.has_error()):
print('Invalid')
else:
print('Valid')
Syntax
Symbol | Description | Example |
---|---|---|
/ |
Slashes at the end of the name marks this path as a folder | root/ |
"" |
Quotes adds regex validation to the file name | "file[0-9]{3}" |
""/ |
Quotes with a slash adds regex validation to the folder name | "folder[0-9]{3}"/ |
* |
Unix style pattern matching for files | *.txt |
*/ |
Unix style pattern matching for folders | log_*/ |
... |
Allows any (and nested) files and folder | ... |
+ |
A + at the start makes the file or folder required |
+required_file.txt |
- |
A - at the start makes the file or folder forbidden |
-forbidden_folder/ |
# |
Write a comment | # cool comment |
Command line
pathschema can be used directly in the command line.
python -m pathschema ./.pathschema path/to/dir/to/validate
Argument details:
usage: __main__.py [-h] [--errors-only] schema directory
Validate a directory against a schema
positional arguments:
schema Path to schema file
directory Path to directory to validate
options:
-h, --help show this help message and exit
--errors-only Only show errors
Development
Installing
python -m pip install -r ./requirements.txt
python -m build
python -m pip install -e .
Running tests
python -m unittest discover -v -s ./tests -p test_*.py
Command line without installing
python ./pathschema/ ./tests/experimentations/test_schema.pathschema ./tests/experimentations/test_directory_ok
Example Schema Definition
Example:
assets/
textures/
*.gif
*.png
materials/
"(trans|solid)_.+\.mat"
+README.md
Only allows .mp4
or .flv
in the videos
folder
videos/
*.mp4
*.flv
This structure would be valid.
videos/
robots.mp4
planets.flv
my-mix-tape.flv
This structure would be invalid. (.png
and .jpg
is not allowed)
videos/
office.png
robots.jpg
Any files and folder allowed in the assets
folder
assets/
...
Any files and directories would be valid in the assets
folder.
assets/
banner.png
backgrounds/
bg_black.png
bg_white.png
Must have a README.md
file
example/
*/
*
+README.md
This structure would be valid.
example/
things/
file.txt
README.md
morethings/
README.md
This structure would be invalid. (Missing README.md
)
example/
things/
file.txt
morethings/
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pathschema-0.2.1.tar.gz
(13.2 kB
view details)
Built Distribution
File details
Details for the file pathschema-0.2.1.tar.gz
.
File metadata
- Download URL: pathschema-0.2.1.tar.gz
- Upload date:
- Size: 13.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4ec45060b1c2288b40acb046f87470f546d50227cbd25d2bd9a851e4c2f8b349 |
|
MD5 | 2db2f412ec8d36fbc66b9c2687056d14 |
|
BLAKE2b-256 | 9a8474b6a4583b3a5e9c43491413396015369a6727c65c52689e5bf75f77b885 |
File details
Details for the file pathschema-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: pathschema-0.2.1-py3-none-any.whl
- Upload date:
- Size: 9.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2a0e67ee5ba81df8d8486a6ade39f2a69464ba60cbb7f92690427161d930c743 |
|
MD5 | e52ae8f14b1cd4085deea542aaa11333 |
|
BLAKE2b-256 | d35ac2c591389c57e1d207081e2f484ffb2c1f6c73366e00505ff8984d5c095c |