2022-06-25 15:03:03 +00:00
|
|
|
"""
|
2022-06-28 06:04:18 +00:00
|
|
|
Generate a minified JSON Ability Tree [atree_constants_min.json] AND a minified .js form [atree_constants_min.js] of the Ability Tree with:
|
2022-06-25 15:03:03 +00:00
|
|
|
- All references replaced by numerical IDs
|
2022-06-27 09:23:22 +00:00
|
|
|
- Extra JSON File with Class: [Original name as key and Assigned IDs as value].
|
2022-06-28 06:04:18 +00:00
|
|
|
given [atree_constants.js] .js form of the Ability Tree with reference as string.
|
2022-06-25 15:03:03 +00:00
|
|
|
"""
|
|
|
|
import json
|
|
|
|
|
2023-11-08 04:31:12 +00:00
|
|
|
def translate_spell_part(id_data, part):
|
|
|
|
if 'hits' in part: # Translate parametrized hits...
|
|
|
|
hits_mapping = part['hits']
|
|
|
|
keys = list(hits_mapping.keys())
|
|
|
|
for k in keys:
|
|
|
|
v = hits_mapping[k]
|
|
|
|
if isinstance(v, str):
|
|
|
|
abil_id, propname = v.split('.')
|
|
|
|
hits_mapping[k] = str(id_data[abil_id])+'.'+propname
|
|
|
|
|
|
|
|
def translate_effect(id_data, effect):
|
|
|
|
if effect["type"] == "raw_stat":
|
|
|
|
for bonus in effect["bonuses"]:
|
|
|
|
if "abil" in bonus and bonus["abil"] in id_data:
|
|
|
|
bonus["abil"] = id_data[bonus["abil"]]
|
|
|
|
elif effect["type"] == "replace_spell":
|
|
|
|
for part in effect['parts']:
|
|
|
|
translate_spell_part(id_data, part)
|
|
|
|
elif effect["type"] == "add_spell_prop":
|
|
|
|
translate_spell_part(id_data, effect)
|
|
|
|
elif effect["type"] == "stat_scaling":
|
|
|
|
if "inputs" in effect: # Might not exist for sliders
|
|
|
|
for _input in effect["inputs"]:
|
|
|
|
if "abil" in _input and _input["abil"] in id_data:
|
|
|
|
_input["abil"] = id_data[_input["abil"]]
|
|
|
|
if "output" in effect:
|
|
|
|
if isinstance(effect["output"], list):
|
|
|
|
for output in effect["output"]:
|
|
|
|
if "abil" in output and output["abil"] in id_data:
|
|
|
|
output["abil"] = id_data[output["abil"]]
|
|
|
|
else:
|
|
|
|
if "abil" in effect["output"] and effect["output"]["abil"] in id_data:
|
|
|
|
effect["output"]["abil"] = id_data[effect["output"]["abil"]]
|
|
|
|
|
|
|
|
def translate_abil(id_data, abil, tree=True):
|
|
|
|
def translate(path, ref):
|
|
|
|
ref_dict = abil
|
|
|
|
for x in path:
|
|
|
|
ref_dict = ref_dict[x]
|
|
|
|
ref_dict[ref] = id_data[ref_dict[ref]]
|
2022-07-02 23:55:10 +00:00
|
|
|
|
2023-11-08 04:31:12 +00:00
|
|
|
for optional_key in ["parents", "dependencies", "blockers"]:
|
|
|
|
if optional_key not in abil:
|
|
|
|
if tree:
|
|
|
|
print(f"WARNING: atree node missing required key [{optional_key}]")
|
|
|
|
continue
|
|
|
|
for ref in range(len(abil[optional_key])):
|
|
|
|
translate([optional_key], ref)
|
2022-07-02 23:55:10 +00:00
|
|
|
|
2023-11-08 04:31:12 +00:00
|
|
|
if "base_abil" in abil:
|
|
|
|
base_abil_name = abil["base_abil"]
|
|
|
|
if base_abil_name in id_data:
|
|
|
|
translate([], "base_abil")
|
2022-07-02 23:55:10 +00:00
|
|
|
|
2023-11-08 04:31:12 +00:00
|
|
|
if "effects" not in abil:
|
|
|
|
print("WARNING: abil missing 'effects' tag")
|
|
|
|
print(abil)
|
|
|
|
abil["effects"] = []
|
|
|
|
for effect in abil["effects"]:
|
|
|
|
translate_effect(id_data, effect)
|
|
|
|
|
|
|
|
def translate_all(id_data, atree_data):
|
|
|
|
for _class, info in atree_data.items():
|
|
|
|
for abil in info:
|
|
|
|
abil["id"] = id_data[_class][abil["display_name"]]
|
|
|
|
translate_abil(id_data[_class], abil)
|
2022-07-02 23:55:10 +00:00
|
|
|
|
|
|
|
|
2022-06-25 15:03:03 +00:00
|
|
|
abilDict = {}
|
2022-06-28 06:04:18 +00:00
|
|
|
with open("atree_constants.js") as f:
|
|
|
|
data = f.read()
|
|
|
|
data = data.replace("const atrees = ", "")
|
|
|
|
data = json.loads(data)
|
2022-06-25 15:03:03 +00:00
|
|
|
for classType, info in data.items():
|
2022-06-27 09:23:22 +00:00
|
|
|
_id = 0
|
|
|
|
abilDict[classType] = {}
|
2022-06-25 15:03:03 +00:00
|
|
|
for abil in info:
|
2022-06-27 09:23:22 +00:00
|
|
|
abilDict[classType][abil["display_name"]] = _id
|
|
|
|
_id += 1
|
2022-06-25 15:03:03 +00:00
|
|
|
|
2022-06-27 09:23:22 +00:00
|
|
|
with open("atree_ids.json", "w", encoding='utf-8') as id_dest:
|
2022-06-25 15:03:03 +00:00
|
|
|
json.dump(abilDict, id_dest, ensure_ascii=False, indent=4)
|
|
|
|
|
2023-11-08 04:31:12 +00:00
|
|
|
translate_all(abilDict, data)
|
2022-06-25 15:03:03 +00:00
|
|
|
|
2023-07-15 01:34:30 +00:00
|
|
|
with open("major_ids_clean.json") as maj_id_file:
|
|
|
|
maj_id_dat = json.load(maj_id_file)
|
|
|
|
for k, v in maj_id_dat.items():
|
|
|
|
for abil in v['abilities']:
|
|
|
|
clazz = abil['class']
|
2023-11-08 04:31:12 +00:00
|
|
|
translate_abil(abilDict[clazz], abil, tree=False)
|
2023-07-15 01:34:30 +00:00
|
|
|
with open("major_ids_min.json", "w", encoding='utf-8') as maj_id_out:
|
|
|
|
json.dump(maj_id_dat, maj_id_out, ensure_ascii=False, separators=(',', ':'))
|
|
|
|
|
2022-06-28 06:04:18 +00:00
|
|
|
data_str = json.dumps(data, ensure_ascii=False, separators=(',', ':'))
|
|
|
|
data_str = "const atrees=" + data_str
|
|
|
|
with open('atree_constants_min.js', 'w', encoding='utf-8') as abil_dest:
|
|
|
|
abil_dest.write(data_str)
|
|
|
|
|
|
|
|
with open('atree_constants_min.json', 'w', encoding='utf-8') as json_dest:
|
|
|
|
json.dump(data, json_dest, ensure_ascii=False, separators=(',', ':'))
|