Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tired-fox/tcfg
Class based type checking configuration library
https://github.com/tired-fox/tcfg
config configuration dynamic json python toml type-check types yaml
Last synced: about 1 month ago
JSON representation
Class based type checking configuration library
- Host: GitHub
- URL: https://github.com/tired-fox/tcfg
- Owner: Tired-Fox
- License: mit
- Created: 2023-02-17T23:55:15.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2023-06-30T17:06:50.000Z (over 1 year ago)
- Last Synced: 2024-11-19T12:31:38.468Z (about 1 month ago)
- Topics: config, configuration, dynamic, json, python, toml, type-check, types, yaml
- Language: Python
- Homepage:
- Size: 846 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tcfg
```python
from tcfg import cfg, Option@cfg.json('cfg.json')
class Config:
# year must be a string. It has a default value of '2023'
year = '2023'
# load must be a boolean. It has a default value of true
load = true
@cfg.toml('cfg.toml')
class Config2:
# year must be a string. Default to ''
year = str
# load must be a boolean. Default to false
load = bool
# Any config class will save to the specified file path unless overridden.
# This includes config classes that are in other config classes.
# This means you can have one master config object in your code that uses many config files.
@cfg.yaml('nested.tml')
class Nested:
# Must be a bool. Defaults to false
enabled = false
# Must be an int. Defaults to 8081
port = 8081
# Can specify multiple specific options.
scope = Option('public', 'private', default='private')
# Must be a list
# Literals are defaults and types are used for valid element types. Literal types are also used in element types.
extensions = ['reload', dict]
options = {
# wildcard type used for validation of extra values not specified as a key in this dict
'*': dict,
'open': false,
# can have recursive nesting
'deep_nesting': {
'random': int
}
}
@cfg.yaml('cfg.yml')
class Config3:
nested = Nested # nested is a sub/nested config section
```