From a4794437d561a01c8bea12d59502e4cc72acfbea Mon Sep 17 00:00:00 2001 From: Viljami Ilola <+@hix.fi> Date: Sat, 27 Apr 2024 00:40:24 +0300 Subject: separate settings from hiscore --- src/sliceitoff/settings/__init__.py | 2 + src/sliceitoff/settings/settings.py | 82 +++++++++++++++++++++++++++++++++++++ src/sliceitoff/settings/static.py | 26 ++++++++++++ 3 files changed, 110 insertions(+) create mode 100644 src/sliceitoff/settings/__init__.py create mode 100644 src/sliceitoff/settings/settings.py create mode 100644 src/sliceitoff/settings/static.py (limited to 'src/sliceitoff/settings') diff --git a/src/sliceitoff/settings/__init__.py b/src/sliceitoff/settings/__init__.py new file mode 100644 index 0000000..99fd1b6 --- /dev/null +++ b/src/sliceitoff/settings/__init__.py @@ -0,0 +1,2 @@ +""" settings - Settings handler """ +from .settings import settings diff --git a/src/sliceitoff/settings/settings.py b/src/sliceitoff/settings/settings.py new file mode 100644 index 0000000..cf588b7 --- /dev/null +++ b/src/sliceitoff/settings/settings.py @@ -0,0 +1,82 @@ +""" settings.settings - handles settings reading, updating and writing """ +import os +from pathlib import Path +from .static import DEFAULT_SETTINGS + +class Settings: + def __init__(self, filename = None): + self.settings=[] + if filename: + self.config_filename = filename + else: + if os.name == 'nt': + self.config_filename = (Path.home().resolve() + .joinpath('sliceitoff.cfg')) + else: + self.config_filename = (Path.home().resolve() + .joinpath('.config').joinpath('sliceitoffrc')) + if not self.config_filename.is_file(): + self.settings=DEFAULT_SETTINGS[:] + return + with open(self.config_filename, "r", encoding="utf-8") as config_file: + for line in config_file: + entry = self.validate_line(line) + if not entry: + continue + self.settings.append(entry) + + def validate_line(self, line): + if not line or line[0] == '#': + return None + data = line.split('=') + if len(data) != 2: + return None + return data[0], data[1] + + def get_values(self, option): + return [x[1] for x in self.settings if x[0]==option] + + def put_values(self, option, values): + for x in values: + self.put_value(option, x) + + def remove_values(self, option): + for x in self.settings[:]: + if x[0]==option: + self.settings.remove(x) + + def replace_values(self, option, values): + self.remove_values(option) + self.put_values(option, values) + + def get_value(self, option): + v = self.get_values(option) + if not v: + return None + return v + + def get_value_or_default(self, option): + v = self.get_values(option) + if v: + return v + return [x[1] for x in DEFAULT_SETTINGS if x[0]==option][1] + + def put_value(self, option, value): + self.settings.append((option, value)) + + def replace_value(self, option, value): + self.remove_values(option) + self.put_value(option, value) + + def save(self): + with open(self.config_filename, 'w', encoding="utf-8") as config_file: + for option, value in self.settings: + config_file.write(f"{option}={value}\n") + +# Initialize only one time +try: + # pylint: disable = used-before-assignment + # This is intented behaviour + settings +except NameError: + settings = Settings() diff --git a/src/sliceitoff/settings/static.py b/src/sliceitoff/settings/static.py new file mode 100644 index 0000000..8c8935b --- /dev/null +++ b/src/sliceitoff/settings/static.py @@ -0,0 +1,26 @@ +""" settings.static - default settings etc static data """ + +DEFAULT_SETTINGS = [ + ("hiscore", "281238!HIL"), + ("hiscore", "190355!VIL"), + ("hiscore", "164710!KSU"), + ("hiscore", "100000!---"), + ("hiscore", "90000!---"), + ("hiscore", "80000!-S-"), + ("hiscore", "70000!-L-"), + ("hiscore", "60000!-I-"), + ("hiscore", "50000!-C-"), + ("hiscore", "40000!-E-"), + ("hiscore", "30000!---"), + ("hiscore", "25000!-I-"), + ("hiscore", "20000!-T-"), + ("hiscore", "15000!---"), + ("hiscore", "10000!-O-"), + ("hiscore", "8000!-F-"), + ("hiscore", "6000!-F-"), + ("hiscore", "4000!---"), + ("hiscore", "2000!---"), + ("hiscore", "0!---"), + ("sfx_volume", "10"), + ("music_volume", "10") +] -- cgit v1.2.3