Merge pull request #71 from hppeng-wynn/atree_hotfix

added nodes to all of the archer abilties in constants (not min yet tho)
This commit is contained in:
hppeng-wynn 2022-07-03 01:21:58 -05:00 committed by GitHub
commit 200a541ecd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 148 additions and 87 deletions

1
.gitignore vendored
View file

@ -1,5 +1,6 @@
*.swp
*.bat
*.json
sets/
.idea/

View file

@ -0,0 +1,5 @@
How to convert:
1. edit `atree_constants.js`
2. run `python3 ../py_script/atree-generateID.py
3. check that the site still works

View file

@ -9,7 +9,8 @@ const atrees = {
"cost": 1,
"display": {
"row": 9,
"col": 6
"col": 6,
"icon": "node_4"
},
"properties": {
"charges": 2,
@ -49,7 +50,8 @@ const atrees = {
"cost": 1,
"display": {
"row": 7,
"col": 4
"col": 4,
"icon": "node_4"
},
"properties": {
"aoe": 0,
@ -73,7 +75,8 @@ const atrees = {
"cost": 1,
"display": {
"row": 0,
"col": 4
"col": 4,
"icon": "node_4"
},
"properties": {
"aoe": 4.5,
@ -111,7 +114,8 @@ const atrees = {
"cost": 1,
"display": {
"row": 4,
"col": 4
"col": 4,
"icon": "node_1"
},
"properties": {},
"effects": [
@ -139,7 +143,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 16,
"col": 6
"col": 6,
"icon": "node_1"
},
"properties": {
"aoe": 0.8,
@ -170,7 +175,7 @@ const atrees = {
"dependencies": ["Arrow Storm"],
"blockers": [],
"cost": 2,
"display": { "row": 16, "col": 8 },
"display": { "row": 16, "col": 8, "icon": "node_1"},
"properties": {
"aoe": 2,
"duration": 5
@ -199,7 +204,7 @@ const atrees = {
"dependencies": ["Arrow Storm"],
"blockers": ["Phantom Ray"],
"cost": 2,
"display": { "row": 15, "col": 2 },
"display": { "row": 15, "col": 2, "icon": "node_1"},
"properties": {},
"effects": [
{
@ -223,7 +228,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 1,
"display": { "row": 9, "col": 2 },
"display": { "row": 9, "col": 2, "icon": "node_4"},
"properties": { "range": 16 },
"effects": [
{
@ -263,7 +268,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 19,
"col": 1
"col": 1,
"icon": "node_3"
},
"properties": {
"range": 4,
@ -311,7 +317,8 @@ const atrees = {
"cost": 1,
"display": {
"row": 10,
"col": 1
"col": 1,
"icon": "node_0"
},
"properties": {
"aoe": 8,
@ -341,7 +348,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 19,
"col": 8
"col": 8,
"icon": "node_3"
},
"properties": {
"aoe": 7,
@ -366,7 +374,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 21,
"col": 1
"col": 1,
"icon": "node_1"
},
"properties": {},
"effects": [
@ -404,7 +413,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 21,
"col": 5
"col": 5,
"icon": "node_2"
},
"properties": {
"range": 26
@ -423,7 +433,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 22,
"col": 6
"col": 6,
"icon": "node_1"
},
"properties": {},
"effects": [
@ -446,7 +457,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 25,
"col": 4
"col": 4,
"icon": "node_2"
},
"properties": {
"range": 64,
@ -480,7 +492,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 2,
"display": { "row": 26, "col": 1 },
"display": { "row": 26, "col": 1, "icon": "node_1"},
"properties": {
"aoe": 4
},
@ -513,7 +525,7 @@ const atrees = {
"dependencies": ["Fire Creep"],
"blockers": [],
"cost": 1,
"display": { "row": 26, "col": 5 },
"display": { "row": 26, "col": 5, "icon": "node_1"},
"properties": {
"duration": 2,
"aoe": 0.4
@ -536,7 +548,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 2,
"display": { "row": 28, "col": 0 },
"display": { "row": 28, "col": 0, "icon": "node_1"},
"properties": {
"cooldown": 2
},
@ -552,7 +564,7 @@ const atrees = {
"dependencies": ["Arrow Bomb"],
"blockers": [],
"cost": 2,
"display": { "row": 28, "col": 4 },
"display": { "row": 28, "col": 4, "icon": "node_1"},
"properties": {
"gravity": 0
},
@ -576,7 +588,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 28,
"col": 8
"col": 8,
"icon": "node_3"
},
"properties": {
"range": 16,
@ -602,7 +615,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 31,
"col": 0
"col": 0,
"icon": "node_1"
},
"properties": {},
"effects": [
@ -630,7 +644,7 @@ const atrees = {
"dependencies": ["Focus"],
"blockers": [],
"cost": 2,
"display": { "row": 31, "col": 5 },
"display": { "row": 31, "col": 5, "icon": "node_2"},
"properties": {},
"effects": []
},
@ -644,7 +658,7 @@ const atrees = {
"dependencies": ["Arrow Shield"],
"blockers": [],
"cost": 2,
"display": { "row": 32, "col": 7 },
"display": { "row": 32, "col": 7, "icon": "node_2"},
"properties": {},
"effects": [
{
@ -665,7 +679,7 @@ const atrees = {
"dependencies": [],
"blockers": ["Phantom Ray"],
"cost": 2,
"display": { "row": 33, "col": 0 },
"display": { "row": 33, "col": 0, "icon": "node_3"},
"properties": {},
"effects": [
{
@ -684,7 +698,7 @@ const atrees = {
"dependencies": ["Fierce Stomp"],
"blockers": [],
"cost": 2,
"display": { "row": 37, "col": 1 },
"display": { "row": 37, "col": 1, "icon": "node_1"},
"properties": {},
"effects": [
{
@ -721,7 +735,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 37,
"col": 4
"col": 4,
"icon": "node_3"
},
"properties": {},
"effects": [
@ -755,7 +770,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 2,
"display": { "row": 37, "col": 7 },
"display": { "row": 37, "col": 7, "icon": "node_2"},
"properties": {
"aoe": 2
},
@ -783,7 +798,7 @@ const atrees = {
"dependencies": ["Basaltic Trap"],
"blockers": [],
"cost": 2,
"display": { "row": 38, "col": 6 },
"display": {"row": 38, "col": 6, "icon": "node_1"},
"properties": {
"attackSpeed": 0.2
},
@ -815,7 +830,8 @@ const atrees = {
"cost": 2,
"display": {
"row": 39,
"col": 2
"col": 2,
"icon": "node_2"
},
"properties": {
"range": 2.5,
@ -833,7 +849,7 @@ const atrees = {
"dependencies": ["Guardian Angels"],
"blockers": [],
"cost": 2,
"display": { "row": 40, "col": 1 },
"display": { "row": 40, "col": 1, "icon": "node_3"},
"properties": {
"range": 8,
"shots": 5
@ -863,7 +879,7 @@ const atrees = {
"dependencies": ["Basaltic Trap"],
"blockers": [],
"cost": 2,
"display": { "row": 40, "col": 7 },
"display": {"row": 40, "col": 7, "icon": "node_3"},
"properties": {},
"effects": [
{
@ -900,7 +916,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 1,
"display": { "row": 2, "col": 4 },
"display": { "row": 2, "col": 4, "icon": "node_0"},
"properties": {},
"effects": [
{
@ -923,7 +939,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 1,
"display": { "row": 2, "col": 6 },
"display": {"row": 2, "col": 6, "icon": "node_0"},
"properties": {},
"effects": [
{
@ -941,7 +957,7 @@ const atrees = {
"dependencies": [],
"blockers": [],
"cost": 1,
"display": { "row": 21, "col": 3 },
"display": {"row": 21, "col": 3, "icon": "node_0"},
"properties": {},
"effects": [
{
@ -1840,7 +1856,7 @@ const atrees = {
"display": {
"row": 17,
"col": 2,
"icon": "node_0"
"icon": "node_1"
},
"properties": {},
"effects": [{

File diff suppressed because one or more lines are too long

View file

@ -13,52 +13,54 @@ with open("atree_ids.json") as f:
with open("atree_constants.json") as f:
atree_data = json.loads(f.read())
for _class, info in atree_data.items():
def translate(path, ref):
ref_dict = info
for x in path:
ref_dict = ref_dict[x]
ref_dict[ref] = id_data[_class][ref_dict[ref]]
for abil in range(len(info)):
info[abil]["id"] = id_data[_class][info[abil]["display_name"]]
for ref in range(len(info[abil]["parents"])):
translate([abil, "parents"], ref)
def translate_id(id_data, atree_data):
for _class, info in atree_data.items():
def translate(path, ref):
ref_dict = info
for x in path:
ref_dict = ref_dict[x]
ref_dict[ref] = id_data[_class][ref_dict[ref]]
for abil in range(len(info)):
info[abil]["id"] = id_data[_class][info[abil]["display_name"]]
for ref in range(len(info[abil]["parents"])):
translate([abil, "parents"], ref)
for ref in range(len(info[abil]["dependencies"])):
translate([abil, "dependencies"], ref)
for ref in range(len(info[abil]["dependencies"])):
translate([abil, "dependencies"], ref)
for ref in range(len(info[abil]["blockers"])):
translate([abil, "blockers"], ref)
for ref in range(len(info[abil]["blockers"])):
translate([abil, "blockers"], ref)
if "base_abil" in info[abil]:
base_abil_name = info[abil]["base_abil"]
if base_abil_name in id_data[_class]:
translate([abil], "base_abil")
if "base_abil" in info[abil]:
base_abil_name = info[abil]["base_abil"]
if base_abil_name in id_data[_class]:
translate([abil], "base_abil")
if "effects" not in info[abil]:
print("WARNING: abil missing 'effects' tag")
print(info[abil])
info[abil]["effects"] = []
for effect in info[abil]["effects"]:
if effect["type"] == "raw_stat":
for bonus in effect["bonuses"]:
if "abil" in bonus and bonus["abil"] in id_data[_class]:
bonus["abil"] = id_data[_class][bonus["abil"]]
if "effects" not in info[abil]:
print("WARNING: abil missing 'effects' tag")
print(info[abil])
info[abil]["effects"] = []
for effect in info[abil]["effects"]:
if effect["type"] == "raw_stat":
for bonus in effect["bonuses"]:
if "abil" in bonus and bonus["abil"] in id_data[_class]:
bonus["abil"] = id_data[_class][bonus["abil"]]
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[_class]:
_input["abil"] = id_data[_class][_input["abil"]]
if isinstance(effect["output"], list):
for output in effect["output"]:
if "abil" in output and output["abil"] in id_data[_class]:
output["abil"] = id_data[_class][output["abil"]]
else:
if "abil" in effect["output"] and effect["output"]["abil"] in id_data[_class]:
effect["output"]["abil"] = id_data[_class][effect["output"]["abil"]]
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[_class]:
_input["abil"] = id_data[_class][_input["abil"]]
if isinstance(effect["output"], list):
for output in effect["output"]:
if "abil" in output and output["abil"] in id_data[_class]:
output["abil"] = id_data[_class][output["abil"]]
else:
if "abil" in effect["output"] and effect["output"]["abil"] in id_data[_class]:
effect["output"]["abil"] = id_data[_class][effect["output"]["abil"]]
translate_id(id_data, atree_data)
with open('atree_constants_idfied.json', 'w', encoding='utf-8') as abil_dest:
json.dump(atree_data, abil_dest, ensure_ascii=False, indent=4)

View file

@ -6,6 +6,53 @@ given [atree_constants.js] .js form of the Ability Tree with reference as string
"""
import json
def translate_id(id_data, atree_data):
for _class, info in atree_data.items():
def translate(path, ref):
ref_dict = info
for x in path:
ref_dict = ref_dict[x]
ref_dict[ref] = id_data[_class][ref_dict[ref]]
for abil in range(len(info)):
info[abil]["id"] = id_data[_class][info[abil]["display_name"]]
for ref in range(len(info[abil]["parents"])):
translate([abil, "parents"], ref)
for ref in range(len(info[abil]["dependencies"])):
translate([abil, "dependencies"], ref)
for ref in range(len(info[abil]["blockers"])):
translate([abil, "blockers"], ref)
if "base_abil" in info[abil]:
base_abil_name = info[abil]["base_abil"]
if base_abil_name in id_data[_class]:
translate([abil], "base_abil")
if "effects" not in info[abil]:
print("WARNING: abil missing 'effects' tag")
print(info[abil])
info[abil]["effects"] = []
for effect in info[abil]["effects"]:
if effect["type"] == "raw_stat":
for bonus in effect["bonuses"]:
if "abil" in bonus and bonus["abil"] in id_data[_class]:
bonus["abil"] = id_data[_class][bonus["abil"]]
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[_class]:
_input["abil"] = id_data[_class][_input["abil"]]
if isinstance(effect["output"], list):
for output in effect["output"]:
if "abil" in output and output["abil"] in id_data[_class]:
output["abil"] = id_data[_class][output["abil"]]
else:
if "abil" in effect["output"] and effect["output"]["abil"] in id_data[_class]:
effect["output"]["abil"] = id_data[_class][effect["output"]["abil"]]
abilDict = {}
with open("atree_constants.js") as f:
data = f.read()
@ -21,17 +68,7 @@ with open("atree_constants.js") as f:
with open("atree_ids.json", "w", encoding='utf-8') as id_dest:
json.dump(abilDict, id_dest, ensure_ascii=False, indent=4)
for classType, info in data.items():
for abil in range(len(info)):
info[abil]["id"] = abilDict[classType][info[abil]["display_name"]]
for ref in range(len(info[abil]["parents"])):
info[abil]["parents"][ref] = abilDict[classType][info[abil]["parents"][ref]]
for ref in range(len(info[abil]["dependencies"])):
info[abil]["dependencies"][ref] = abilDict[classType][info[abil]["dependencies"][ref]]
for ref in range(len(info[abil]["blockers"])):
info[abil]["blockers"][ref] = abilDict[classType][info[abil]["blockers"][ref]]
translate_id(abilDict, data)
data_str = json.dumps(data, ensure_ascii=False, separators=(',', ':'))
data_str = "const atrees=" + data_str