forked from Ridepad/uwu-logs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser_profile_talents.py
135 lines (103 loc) · 3.86 KB
/
parser_profile_talents.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
from c_path import Directories
from parser_talents_data import (
TALENTS,
TALENTS_ENCODE_STR,
)
class TalentsParsed:
def __init__(
self,
main_spec_name: str,
talents_allocated_str: str,
encoded_string: str,
):
self.main_spec_name = main_spec_name
self.talents_allocated_str = talents_allocated_str
self.encoded_string = encoded_string
def add_glyphs_to_talent_string(self, encoded_glyphs: str):
if encoded_glyphs:
self.encoded_string = f"{self.encoded_string}:{encoded_glyphs}"
def as_list(self):
return [
self.main_spec_name,
self.talents_allocated_str,
self.encoded_string,
]
class Talent:
def __init__(self, **kwargs):
self.spell_id = int(kwargs["spell"])
self.spec = kwargs["spec"] or 0
self.name = kwargs["name"] or ""
def __str__(self):
return " | ".join((
f"{self.spell_id:>5}",
f"{self.spec}",
f"{self.name}",
))
def convert_to_string(talents_tree: list[int]):
if len(talents_tree) & 1:
talents_tree.append(0)
z = zip(talents_tree[::2], talents_tree[1::2])
g = (TALENTS_ENCODE_STR[r1 * 6 + r2] for r1, r2 in z)
s = "".join(g)
if s[-1] == TALENTS_ENCODE_STR[0]:
return s.rstrip(TALENTS_ENCODE_STR[0]) + "Z"
return s
def convert_spec_to_string(trees: list[list[int]]):
tree_gen = (convert_to_string(tree) for tree in trees)
return "".join(tree_gen).rstrip("Z")
class PlayerTalents:
def __init__(self, class_name: str):
self.class_name = class_name
self.class_talents = TALENTS[class_name]
def spec_data(self, trees: list[list[int]]):
tree_string = convert_spec_to_string(trees)
tree_string = self.class_talents.prefix + tree_string
allocated = [sum(tree) for tree in trees]
spec_index_max_allocated = allocated.index(max(allocated))
main_spec = self.class_talents.trees[spec_index_max_allocated]
talents_allocated_str = "/".join(map(str, allocated))
return TalentsParsed(
main_spec.spec_name,
talents_allocated_str,
tree_string,
)
class PlayerTalentsWC(PlayerTalents):
def convert_talents(self, allocated_talents: list[int]):
trees_d = self.class_talents.empty_trees()
for spell_id in allocated_talents:
talent = self.class_talents.find_spec(spell_id)
if not talent:
continue
trees_d[talent.tree_index][talent.talent_index] = talent.level
return trees_d.values()
def get_talents_data(self, allocated_talents: list[int]):
trees = self.convert_talents(allocated_talents)
return self.spec_data(trees)
class PlayerTalentsRG(PlayerTalents):
def convert_talents(self, allocated_points: str):
trees: list[list[int]] = []
for tree in self.class_talents.trees:
tree_size = len(tree.nodes)
current_tree = allocated_points[:tree_size]
allocated_points = allocated_points[tree_size:]
trees.append(list(map(int, current_tree)))
return self.spec_data(trees)
def get_talents_data(self, allocated_points: str):
return self.convert_talents(allocated_points).as_list()
def get_talents_data_list(self, talents: list[str]):
return [
self.get_talents_data(allocated_points)
for allocated_points in talents
]
def main():
qf = Directories.temp / "test_wc_talents.json"
q = qf.json()
data = q["result"]["data"]
print(data)
q2 = [Talent(**x).spell_id for x in data]
# pt = PlayerTalents("Hunter", q2)
pt = PlayerTalentsWC("Druid", q2)
z = pt.convert_to_talents_string()
print(z)
if __name__ == "__main__":
main()