forked from Ridepad/uwu-logs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogs_top.py
189 lines (164 loc) · 5.93 KB
/
logs_top.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
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
from collections import defaultdict
from time import perf_counter
import logs_main
from c_path import FileNames
from h_debug import Loggers, get_ms_str, running_time
from logs_auras_v2 import (
AuraUptimeDuration,
AURAS_SELF,
AURAS_EXTERNAL,
AURAS_BOSS_MECHANICS,
AURAS_SPEC,
)
try:
import _validate
except ImportError:
_validate = None
LOGGER_REPORTS = Loggers.reports
Z_SPELLS = [
AURAS_EXTERNAL,
AURAS_SELF,
AURAS_BOSS_MECHANICS,
AURAS_SPEC,
]
HUNGER_FOR_BLOOD = "63848"
OVERKILL = "58427"
CLEARCASTING = "16870"
FOCUS_MAGIC = "54646"
BATTLE_SQUAWK = "23060"
TRICKS_OF_TRADE = "57933"
SPECS_NO_USE_FOR_CHICKEN = {*range(12, 16), *range(20, 24), 29, 31, 33, 35}
def f_auras(auras: dict[str, AuraUptimeDuration], spec: int):
if spec == 25:
if HUNGER_FOR_BLOOD in auras:
del auras[HUNGER_FOR_BLOOD]
if OVERKILL in auras:
del auras[OVERKILL]
if spec != 6 and CLEARCASTING in auras:
del auras[CLEARCASTING]
if spec in range(24, 28) and TRICKS_OF_TRADE in auras:
del auras[TRICKS_OF_TRADE]
if spec in range(12, 16) and FOCUS_MAGIC in auras:
del auras[FOCUS_MAGIC]
if spec in SPECS_NO_USE_FOR_CHICKEN and BATTLE_SQUAWK in auras:
del auras[BATTLE_SQUAWK]
zz = []
for type_index, auras_dict in enumerate(Z_SPELLS):
for spell_id in auras_dict:
if spell_id not in auras:
continue
aura = auras[spell_id]
zz.append([int(spell_id), aura.count, aura.uptime, type_index])
return zz
class Top(logs_main.THE_LOGS):
def make_report_top_wrap(self, rewrite=False):
top_path = self.relative_path(FileNames.logs_top)
if not rewrite and top_path.is_file():
return
pc = perf_counter()
q = _validate and _validate.pure_dog_water(self)
if q:
report_top = {}
LOGGER_REPORTS.debug(f'{get_ms_str(pc)} | {self.NAME:50} | Dog water | {q}')
else:
report_top = self.make_report_top()
LOGGER_REPORTS.debug(f'{get_ms_str(pc)} | {self.NAME:50} | Done top')
top_path.json_write(report_top)
return report_top
@running_time
def make_report_top(self):
report_top = defaultdict(dict)
for boss_name, kill_segment in self.gen_kill_segments():
diff = kill_segment['diff']
s = kill_segment["start"]
f = kill_segment["end"]
report_top[boss_name][diff] = self.make_boss_top(s, f, boss_name)
return report_top
def get_vali_heal(self, s, f):
data = defaultdict(lambda: defaultdict(int))
for line in self.LOGS[s:f]:
if "_H" not in line:
continue
_line = line.split(',', 11)
data[_line[4]][_line[2]] += int(_line[9]) - int(_line[10])
return data
def get_vali_heal_wrap(self, s, f):
vali_data = self.get_vali_heal(s, f)
_useful = defaultdict(int)
_total = defaultdict(int)
for tguid, sources in vali_data.items():
# totems worked until ~21-12-20
# if tguid[5:12] == "0008FB5":
# for sguid, v in sources.items():
# dmg_useful[_sguid] += v
if tguid[5:12] == "0008FB5":
_useful = sources
for sguid, v in sources.items():
_sguid = self.get_master_guid(sguid)
_total[_sguid] += v
return {
"useful_total": _useful,
"damage_total": _total,
}
@running_time
def make_boss_top(self, s, f, boss_name: str):
def is_player(guid):
if guid in PLAYERS:
return True
# LOGGER_REPORTS.error(f"{report.NAME} {boss_name} Missing player {report.guid_to_name(guid)}")
PLAYERS = self.get_players_guids()
SPECS = self.get_players_specs_in_segments(s, f)
DURATION = self.get_slice_duration(s, f)
AURAS = self.get_auras_uptime_percentage(s, f)
if boss_name == "Valithria Dreamwalker":
_data = self.get_vali_heal_wrap(s, f)
else:
_damage = self.target_damage(s, f)
_total = _damage["total"]
_no_overkill = _damage["no_overkill"]
_specific = self.target_damage_specific(s, f, boss_name)
_data = self.target_damage_combine(_total, _no_overkill, _specific)
all_total = _data["damage_total"]
all_useful = _data["useful_total"]
return [
{
'r': self.NAME,
't': DURATION,
'i': guid[-7:],
'n': PLAYERS[guid],
'u': useful,
'd': all_total[guid],
's': SPECS[guid],
'a': f_auras(AURAS[guid], SPECS[guid])
}
for guid, useful in all_useful.items()
if is_player(guid)
]
def make_report_top_wrap(report_name, rewrite=False):
try:
t = Top(report_name)
t.make_report_top_wrap(rewrite=rewrite)
return True
except Exception:
LOGGER_REPORTS.exception(report_name)
def _print_boss_top(boss_top: list[dict]):
for x in sorted(boss_top, key=lambda x: x["u"], reverse=True):
q = f"{x['n']:12} | {x['u']:>11,} | {x['d']:>11,}"
print(q)
def _test1():
make_report_top_wrap("24-05-10--21-04--Jengo--Lordaeron", True)
make_report_top_wrap("24-09-06--20-54--Meownya--Lordaeron", True)
make_report_top_wrap("24-08-30--21-04--Meownya--Lordaeron", True)
def _test2():
# report = Top("24-02-09--20-49--Meownya--Lordaeron")
report = Top("24-05-10--21-04--Jengo--Lordaeron")
data = report.make_report_top()
# lk = data["The Lich King"]["25H"]
# for x in lk:
# print(x)
# vali = data["Valithria Dreamwalker"]["25H"]
# _print_boss_top(vali)
fg = data["Festergut"]["25H"]
_print_boss_top(fg)
if __name__ == "__main__":
_test1()