Merge branch 'main' into feature/pointwisePolytrope
This commit is contained in:
@@ -31,6 +31,9 @@ def parse_value(value, type_hint):
|
||||
if type_hint in {"int", "long"}:
|
||||
return (int(value), type_hint)
|
||||
elif type_hint in {"float", "double"}:
|
||||
return float(value)
|
||||
elif value == "defaultDataDir":
|
||||
return "data" # special case for defaultDataDir
|
||||
return (float(value), type_hint)
|
||||
elif type_hint == "bool":
|
||||
return (value.lower() in {"true", "1"}, type_hint)
|
||||
@@ -38,6 +41,9 @@ def parse_value(value, type_hint):
|
||||
return (value.strip('"'), type_hint) # Remove quotes for string literals
|
||||
elif value.startswith("'") and value.endswith("'"):
|
||||
return (value.strip("'"), type_hint) # Remove single quotes
|
||||
return value.strip("'") # Remove single quotes
|
||||
elif value.startswith('"') and value.endswith('"'):
|
||||
return (value.strip('"'). type_hint)# Remove quotes for string literals
|
||||
|
||||
return (value, type_hint) # Return as-is if unsure
|
||||
|
||||
@@ -66,10 +72,19 @@ def scan_files(directory):
|
||||
print(f"Match: {match.group()}")
|
||||
type_hint, hierarchy, value = match.groups()
|
||||
keys = hierarchy.split(":")
|
||||
if keys[0] == "Data" and keys[1] == "Dir":
|
||||
continue # Skip Data:Dir as it is a special case
|
||||
insert_into_dict(hierarchy_dict, keys, value, type_hint)
|
||||
|
||||
return hierarchy_dict
|
||||
|
||||
class QuotedString(str):
|
||||
pass
|
||||
|
||||
def represent_quoted_string(dumper, data):
|
||||
return dumper.represent_scalar('tag:yaml.org,2002:str', data, style='"')
|
||||
|
||||
|
||||
def split_dict_recursive(originalDict):
|
||||
dataDict = {}
|
||||
typeDict = {}
|
||||
@@ -87,6 +102,19 @@ def split_dict_recursive(originalDict):
|
||||
|
||||
def save_yaml(data, output_file):
|
||||
"""Saves the nested dictionary to a YAML file."""
|
||||
yaml.add_representer(QuotedString, represent_quoted_string)
|
||||
|
||||
def quote_strings(data):
|
||||
if isinstance(data, dict):
|
||||
return {k: quote_strings(v) for k, v in data.items()}
|
||||
elif isinstance(data, list):
|
||||
return [quote_strings(item) for item in data]
|
||||
elif isinstance(data, str):
|
||||
return QuotedString(data)
|
||||
else:
|
||||
return data
|
||||
|
||||
data = quote_strings(data)
|
||||
options, types = split_dict_recursive(data)
|
||||
with open(output_file, 'w', encoding='utf-8') as f:
|
||||
yaml.dump(options, f, default_flow_style=False, sort_keys=False, indent=4)
|
||||
|
||||
Reference in New Issue
Block a user