67 lines
2.1 KiB
Python
67 lines
2.1 KiB
Python
from .database import *
|
|
from .s23_options_util import get_option_schema, generate_v3
|
|
from .batch_cmd import execute_batch_command
|
|
|
|
|
|
def set_option(name: str, cs: ChangeSet) -> ChangeSet:
|
|
cs.operations[0]['operation'] = API_UPDATE
|
|
cs.operations[0]['type'] = 'option'
|
|
new_cs = cs
|
|
new_cs.merge(generate_v3(cs))
|
|
return execute_batch_command(name, new_cs)
|
|
|
|
|
|
def inp_in_option(section: list[str]) -> ChangeSet:
|
|
if len(section) <= 0:
|
|
return ChangeSet()
|
|
|
|
cs = g_update_prefix | { 'type' : 'option' }
|
|
for s in section:
|
|
if s.startswith(';'):
|
|
continue
|
|
|
|
tokens = s.strip().split()
|
|
if tokens[0].upper() == 'PATTERN': # can not upper id
|
|
value = tokens[1] if len(tokens) > 1 else ''
|
|
cs |= { 'PATTERN' : value }
|
|
elif tokens[0].upper() == 'QUALITY': # can not upper trace node
|
|
value = tokens[1] if len(tokens) > 1 else ''
|
|
if len(tokens) > 2:
|
|
value += f' {tokens[2]}'
|
|
cs |= { 'QUALITY' : value }
|
|
else:
|
|
line = s.upper().strip()
|
|
for key in get_option_schema('').keys():
|
|
if line.startswith(key):
|
|
value = line.removeprefix(key).strip()
|
|
cs |= { key : value }
|
|
|
|
result = ChangeSet(cs)
|
|
result.merge(generate_v3(result))
|
|
return result
|
|
|
|
|
|
def inp_in_option_new(section: list[str]) -> str:
|
|
sql = ''
|
|
result = inp_in_option(section)
|
|
for op in result.operations:
|
|
for key in op.keys():
|
|
if key == 'operation' or key == 'type':
|
|
continue
|
|
if op['type'] == 'option':
|
|
sql += f"update options set value = '{op[key]}' where key = '{key}';"
|
|
else:
|
|
sql += f"update options_v3 set value = '{op[key]}' where key = '{key}';"
|
|
return sql
|
|
|
|
|
|
def inp_out_option(name: str) -> list[str]:
|
|
lines = []
|
|
objs = read_all(name, f"select * from options")
|
|
for obj in objs:
|
|
key = obj['key']
|
|
value = obj['value']
|
|
if str(value).strip() != '':
|
|
lines.append(f'{key} {value}')
|
|
return lines
|