Command for cascading toml files together
Project description
Introduction
Command for cascading toml "databases" into their full objects
TOML cascades are file trees that define generic configuration. Cascading allows for shared setting to be set in one place.
The root of a cascade has two files that define it:
.cascade.tomldefines settings forcascadetoml. Settings are:pathsa list of strings where each string is a python format-style string. These strings are used to pull out setting defined by the path.
<type>.template.tomldefines the full structure of the resulting TOML object.<type>is used as the name for the array of tables output when a cascade results in multiple objects. The keys in the table are the only ones allowed in TOML files within the tree. The types of values must also be consistent.
Settings for a particular folder are in a TOML file with the folder name plus the .toml extension.
The first repo using this is the
nvm.toml repo. Its only path is {technology}/{manufacturer}/{sku}.toml. A file such as flash/gigadevice/GD1.toml will have the implicit values:
technology = "flash"
manufacturer = "gigadevice"
sku = "GD1"
All of the other values come from these files in order:
flash/flash.tomlflash/gigadevice/gigadevice.tomlflash/gigadevice/GD1.toml
No key may exist at multiple levels.
cascadetoml check can be used to validate much of this.
Installing from PyPI
To install for current user:
pip3 install cascadetoml
To install system-wide (this may be required in some cases):
sudo pip3 install cascadetoml
To install in a virtual environment in your current project:
mkdir project-name && cd project-name
python3 -m venv .env
source .env/bin/activate
pip3 install cascadetoml
Installing for development
cascadetoml uses flit for packaging. To install a development copy into your current venv do:
flit install -s --deps develop
After install, you simply edit the files in place and the venv will use the source files directly.
Contributing
Contributions are welcome! Please read our Code of Conduct before contributing to help this project stay welcoming.
Documentation
For information on building library documentation, please check out this guide.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cascadetoml-0.3.3.tar.gz.
File metadata
- Download URL: cascadetoml-0.3.3.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.26.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c15dd247f83ec087a5f91fe80be832116abddde67bca28018aa5fa7a7be01387
|
|
| MD5 |
3ef219e86f1a6ba923ec30277361d999
|
|
| BLAKE2b-256 |
bdb30df5b3236d53b477bc63a9523dd65f84fa642a30ff8272bdd3f3f9b79c0e
|
File details
Details for the file cascadetoml-0.3.3-py2.py3-none-any.whl.
File metadata
- Download URL: cascadetoml-0.3.3-py2.py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.26.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7259634c7654fd537cb2dbd095f6c50348c641e09b4f0a7d19c610ce466851c
|
|
| MD5 |
2ea944986770b39e58bb1dd2a2ecb101
|
|
| BLAKE2b-256 |
0ebc3cf8b583e6ac55ff1e659525b9ec07325be0552ba1aad26387060c83818e
|