From 2002b1f24698d91f0c6fc2b0550cd0043fbc2db2 Mon Sep 17 00:00:00 2001 From: "WQY\\qiong" Date: Mon, 14 Nov 2022 21:24:00 +0800 Subject: [PATCH] Parse [QUALITY] --- api/s17_quality.py | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/api/s17_quality.py b/api/s17_quality.py index acb18cd..b1063b7 100644 --- a/api/s17_quality.py +++ b/api/s17_quality.py @@ -57,3 +57,36 @@ def set_quality_cache(name: str, cs: ChangeSet) -> SqlChangeSet: def set_quality(name: str, cs: ChangeSet) -> ChangeSet: return execute_command(name, set_quality_cache(name, cs)) + + +class InpQuality: + def __init__(self, line: str) -> None: + tokens = line.split() + + num = len(tokens) + has_desc = tokens[-1].startswith(';') + num_without_desc = (num - 1) if has_desc else num + + self.node = str(tokens[0]) + self.quality = float(tokens[1]) + + +def inp_in_quality(section: list[str]) -> ChangeSet: + cs = ChangeSet() + for s in section: + # skip comment + if s.startswith(';'): + continue + obj = InpQuality(s) + cs.append({'operation': API_UPDATE, 'type': 'quality', 'node': obj.node, 'quality': obj.quality}) + return cs + + +def inp_out_quality(name: str) -> list[str]: + lines = [] + objs = read_all(name, 'select * from quality') + for obj in objs: + node = obj['node'] + quality = obj['quality'] + lines.append(f'{node} {quality}') + return lines