prevent saving settings with bogus values

This commit is contained in:
AUTOMATIC
2022-09-23 17:27:30 +03:00
parent 79e7c39298
commit 6fa20d51dc
3 changed files with 22 additions and 20 deletions

View File

@@ -219,6 +219,7 @@ options_templates.update(options_section(('ui', "User interface"), {
class Options:
data = None
data_labels = options_templates
typemap = {int: float}
def __init__(self):
self.data = {k: v.default for k, v in self.data_labels.items()}
@@ -244,25 +245,23 @@ class Options:
with open(filename, "w", encoding="utf8") as file:
json.dump(self.data, file)
def same_type(self, x, y):
if x is None or y is None:
return True
type_x = self.typemap.get(type(x), type(x))
type_y = self.typemap.get(type(y), type(y))
return type_x == type_y
def load(self, filename):
with open(filename, "r", encoding="utf8") as file:
self.data = json.load(file)
typemap = {int: float}
def same_type(x, y):
if x is None or y is None:
return True
type_x = typemap.get(type(x), type(x))
type_y = typemap.get(type(y), type(y))
return type_x == type_y
bad_settings = 0
for k, v in self.data.items():
info = self.data_labels.get(k, None)
if info is not None and not same_type(info.default, v):
if info is not None and not self.same_type(info.default, v):
print(f"Warning: bad setting value: {k}: {v} ({type(v).__name__}; expected {type(info.default).__name__})", file=sys.stderr)
bad_settings += 1