voicemeeter-compact/vmcompact/configurations.py

99 lines
2.7 KiB
Python
Raw Normal View History

import logging
2022-04-11 18:35:28 +01:00
from pathlib import Path
try:
import tomllib
except ModuleNotFoundError:
import tomli as tomllib
2023-06-26 13:53:38 +01:00
logger = logging.getLogger(__name__)
2022-04-11 18:35:28 +01:00
configuration = {}
2023-06-26 13:53:38 +01:00
def get_configpath():
configpaths = [
2025-01-15 20:56:37 +00:00
Path.cwd() / 'configs',
Path.home() / '.config' / 'vm-compact' / 'configs',
Path.home() / 'Documents' / 'Voicemeeter' / 'configs',
]
for configpath in configpaths:
if configpath.exists():
return configpath
if configpath := get_configpath():
2025-01-15 20:56:37 +00:00
filepaths = list(configpath.glob('*.toml'))
if any(f.stem in ('app', 'vban') for f in filepaths):
configs = {}
for filepath in filepaths:
2025-01-15 20:56:37 +00:00
filename = filepath.with_suffix('').stem
if filename in ('app', 'vban'):
try:
2025-01-15 20:56:37 +00:00
with open(filepath, 'rb') as f:
configs[filename] = tomllib.load(f)
2025-01-15 20:56:37 +00:00
logger.info(f'configuration: {filename} loaded into memory')
except tomllib.TOMLDecodeError:
2025-01-15 20:56:37 +00:00
logger.error(f'Invalid TOML config: configs/{filename.stem}')
configuration |= configs
_defaults = {
2025-01-15 20:56:37 +00:00
'configs': {
'config': None,
},
2025-01-15 20:56:37 +00:00
'theme': {
'enabled': True,
'mode': 'light',
},
2025-01-15 20:56:37 +00:00
'extends': {
'extended': True,
'extends_horizontal': True,
},
2025-01-15 20:56:37 +00:00
'channel': {
'width': 80,
'height': 130,
'xpadding': 3,
},
2025-01-15 20:56:37 +00:00
'mwscroll_step': {
'size': 3,
},
2025-01-15 20:56:37 +00:00
'submixes': {
'default': 0,
},
2025-01-15 20:56:37 +00:00
'navigation': {'show': True},
}
2025-01-15 20:56:37 +00:00
if 'app' in configuration:
for key in _defaults:
2025-01-15 20:56:37 +00:00
if key in configuration['app']:
configuration['app'][key] = _defaults[key] | configuration['app'][key]
else:
2025-01-15 20:56:37 +00:00
configuration['app'][key] = _defaults[key]
else:
2025-01-15 20:56:37 +00:00
configuration['app'] = _defaults
def get_configuration(key):
if key in configuration:
return configuration[key]
def loader(kind_id, target):
2025-01-15 20:56:37 +00:00
configs = {'reset': target.configs['reset']}
if configpath := get_configpath():
userconfigpath = configpath / kind_id
if userconfigpath.exists():
2025-01-15 20:56:37 +00:00
filepaths = list(userconfigpath.glob('*.toml'))
for filepath in filepaths:
2025-01-15 20:56:37 +00:00
identifier = filepath.with_suffix('').stem
try:
2025-01-15 20:56:37 +00:00
with open(filepath, 'rb') as f:
configs[identifier] = tomllib.load(f)
2025-01-15 20:56:37 +00:00
logger.info(f'loader: {identifier} loaded into memory')
except tomllib.TOMLDecodeError:
2025-01-15 20:56:37 +00:00
logger.error(f'Invalid TOML config: configs/{filename.stem}')
target.configs = configs
return target.configs