No project description provided
Project description
SunsetSettings
SunsetSettings is a library that provides facilities to declare and use settings for an interactive application in a type-safe manner, and load and save them in a simple INI-like format.
The settings can safely store arbitrary types, and can be structured in an arbitrarily deep hierarchy of subsections, which allows you to implement overrides per project, per folder, per user, etc.
It is mainly intended for software where the user can change settings on the fly, for instance with a settings dialog, and those settings need to be preserved between sessions.
Examples
Creating settings:
>>> from sunset import Bunch, Key, List, Settings
>>> class BackupToolSettings(Settings):
...
... class UI(Bunch):
...
... class Font(Bunch):
... name = Key(default="Arial")
... size = Key(default=12)
...
... font = Font()
... theme = Key(default="")
...
... class Backup(Bunch):
... folder = Key(default="~")
... destination = Key(default="/mnt/backups")
... compress = Key(default=True)
...
... ui = UI()
... backups = List(Backup())
Loading and saving settings:
>>> from sunset import AutoSaver
>>> def main_program_loop(settings: BackupToolSettings):
... ...
>>> settings = BackupToolSettings()
>>> with AutoSaver(settings, "~/.config/backup.conf"): # doctest: +SKIP
... main_program_loop(settings)
Using settings values:
>>> def do_backup(source: str, destination: str, use_compression: bool):
... ...
>>> def do_all_backups(settings: BackupToolSettings):
... for backup in settings.backups:
... do_backup(
... source=backup.folder.get(),
... destination=backup.destination.get(),
... use_compression=backup.compress.get(),
... )
>>> do_all_backups(settings)
Changing settings values:
>>> def update_font_settings(
... font_name: str,
... font_size: int,
... font_settings: BackupToolSettings.UI.Font,
... ):
... font_settings.name.set(font_name)
... font_settings.size.set(font_size)
>>> update_font_settings("Verdana", 11, settings.ui.font)
Reacting to setting value changes:
>>> def apply_theme(new_theme_name: str):
... ...
>>> def setup_theme_change_logic(ui_settings: BackupToolSettings.UI):
... ui_settings.theme.onValueChangeCall(apply_theme)
>>> setup_theme_change_logic(settings.ui)
Features
Type safety
SunsetSettings is type-safe; that is to say, if you are holding it wrong, type checkers will tell you.
>>> from sunset import Key
>>> # Types can be inferred from the provided default value:
>>> number_of_ponies = Key(default=0)
>>> number_of_ponies
<Key[int]:(0)>
>>> number_of_ponies.set(6) # Works!
True
>>> number_of_ponies.set("six") # Type error!
False
>>> number_of_ponies.get() # Value is unchanged.
6
>>> from typing import TYPE_CHECKING
>>> if TYPE_CHECKING:
... reveal_type(number_of_ponies.get())
>>> # Revealed type is "builtins.int"
Extensibility
You can store arbitrary types in your SunsetSettings provided that you also provide a serializer for that type. (See the API reference.)
>>> import re
>>> from typing import Optional, TYPE_CHECKING
>>> class Coordinates:
... def __init__(self, x: int, y: int) -> None:
... self.x = x
... self.y = y
>>> class CoordinatesSerializer:
... def toStr(self, coord: Coordinates) -> str:
... return f"{coord.x},{coord.y}"
...
... def fromStr(self, string: str) -> Optional[Coordinates]:
... x, y = string.split(",", 1)
... if not x.isdigit() or not y.isdigit():
... return None
... return Coordinates(int(x), int(y))
>>> from sunset import Key
>>> coordinates = Key(
... default=Coordinates(0, 0), serializer=CoordinatesSerializer()
... )
>>> if TYPE_CHECKING:
... reveal_type(coordinates.get())
>>> # Revealed type is "Coordinates"
>>> print(repr(coordinates))
<Key[Coordinates]:(0,0)>
Inheritance
SunsetSettings lets the user have a general set of settings that can be partially overriden in subsections used in specific cases (much like your VSCode settings can be overriden by workspace, for instance). The hierarchy of subsections can be arbitrarily deep.
>>> from sunset import Key, Settings
>>> class Animals(Settings):
... limbs: Key[int] = Key(default=4)
...
>>> animals = Animals()
>>> octopuses = animals.newSection(name="octopuses")
>>> octopuses.limbs.get()
4
>>> octopuses.limbs.set(8)
True
>>> octopuses.limbs.get()
8
>>> animals.limbs.get()
4
>>> octopuses.limbs.clear()
>>> octopuses.limbs.get()
4
Callbacks
Each setting key can be given callbacks to be called when its value changes.
>>> from sunset import Key
>>> number_of_ponies = Key(default=0)
>>> def callback(value: int):
... print("Pony count updated:", value)
>>> number_of_ponies.onValueChangeCall(callback)
>>> number_of_ponies.set(6)
Pony count updated: 6
True
Requirements
- Python 3.10 or later.
Installation
Installing from PyPI (recommended)
SunsetSettings releases are available from PyPI and can be installed with the standard Python tooling.
Directly add SunsetSettings
to your project's dependencies or, in order to manually
install SunsetSettings and make it available in the current Python prefix, run:
pip install SunsetSettings
This will install the latest version of SunsetSettings, with its required
dependencies, if any. The module can then be imported under the name sunset
:
>>> import sunset
>>>
Installing from sources
-
Download the code:
git clone https://github.com/pvaret/SunsetSettings
-
Install the library:
cd SunsetSettings ; pip install .
That's it.
API documentation
The API documentation is available at https://sunsetsettings.readthedocs.io/.
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
Built Distribution
File details
Details for the file sunsetsettings-0.6.1.tar.gz
.
File metadata
- Download URL: sunsetsettings-0.6.1.tar.gz
- Upload date:
- Size: 80.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d48534015909936e337562d469c967128a68c397dfcb35a21882e1cca826bb7c |
|
MD5 | 129ba3298f7562f633220aa6cc963418 |
|
BLAKE2b-256 | 0ed7085f695d0aa6683cf5766eef2b04804865747805fec929e90b5144ecb23e |
File details
Details for the file sunsetsettings-0.6.1-py3-none-any.whl
.
File metadata
- Download URL: sunsetsettings-0.6.1-py3-none-any.whl
- Upload date:
- Size: 57.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7f76f921d2fc5dc5ea83cf10a649592f846c361ac08feb7b7b963e0619671998 |
|
MD5 | 82385755b609a1fc18aceb0ff8c600df |
|
BLAKE2b-256 | c56b888309da8899579c557ffa00bd8c1bc87684019e4f7bd91ab1cb90626a36 |