Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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
```