Shows error snippet on empty log (#6)

* Error snippet shown on empty log
- Shader cache corruption warning

* Loop to get missing info in log

* Error search handles multiple terms
- Minor spelling correction for resolution value
- User settings visible on empty log
This commit is contained in:
Mark Araujo 2021-06-18 19:29:31 +01:00 committed by TSR Berry
parent 9bb4aeed9a
commit 82958d47cb
No known key found for this signature in database
GPG key ID: 52353C0A4CCA15E2

View file

@ -66,51 +66,71 @@ class LogFileReader(Cog):
log_file = re.search(log_file_header_regex, log_file).group(0) log_file = re.search(log_file_header_regex, log_file).group(0)
def get_hardware_info(log_file=log_file): def get_hardware_info(log_file=log_file):
for setting in self.embed["hardware_info"]:
try: try:
self.embed["hardware_info"]["cpu"] = ( if setting == "cpu":
self.embed["hardware_info"][setting] = (
re.search(r"CPU:\s([^;\n\r]*)", log_file, re.MULTILINE) re.search(r"CPU:\s([^;\n\r]*)", log_file, re.MULTILINE)
.group(1) .group(1)
.rstrip() .rstrip()
) )
self.embed["hardware_info"]["ram"] = ( if setting == "ram":
re.search(r"RAM:(\sTotal)?\s([^;\n\r]*)", log_file, re.MULTILINE) self.embed["hardware_info"][setting] = (
re.search(
r"RAM:(\sTotal)?\s([^;\n\r]*)", log_file, re.MULTILINE
)
.group(2) .group(2)
.rstrip() .rstrip()
) )
self.embed["hardware_info"]["os"] = ( if setting == "os":
re.search(r"Operating System:\s([^;\n\r]*)", log_file, re.MULTILINE) self.embed["hardware_info"][setting] = (
re.search(
r"Operating System:\s([^;\n\r]*)",
log_file,
re.MULTILINE,
)
.group(1) .group(1)
.rstrip() .rstrip()
) )
self.embed["hardware_info"]["gpu"] = ( if setting == "gpu":
self.embed["hardware_info"][setting] = (
re.search( re.search(
r"PrintGpuInformation:\s([^;\n\r]*)", log_file, re.MULTILINE r"PrintGpuInformation:\s([^;\n\r]*)",
log_file,
re.MULTILINE,
) )
.group(1) .group(1)
.rstrip() .rstrip()
) )
except AttributeError: except AttributeError:
pass continue
def get_ryujinx_info(log_file=log_file): def get_ryujinx_info(log_file=log_file):
# try:
for setting in self.embed["emu_info"]:
try: try:
self.embed["emu_info"]["ryu_version"] = [ if setting == "ryu_version":
self.embed["emu_info"][setting] = [
line.split()[-1] line.split()[-1]
for line in log_file.splitlines() for line in log_file.splitlines()
if "Ryujinx Version:" in line if "Ryujinx Version:" in line
][0] ][0]
self.embed["emu_info"]["logs_enabled"] = ( if setting == "logs_enabled":
re.search(r"Logs Enabled:\s([^;\n\r]*)", log_file, re.MULTILINE) self.embed["emu_info"][setting] = (
re.search(
r"Logs Enabled:\s([^;\n\r]*)", log_file, re.MULTILINE
)
.group(1) .group(1)
.rstrip() .rstrip()
) )
if setting == "ryu_firmware":
self.embed["emu_info"]["ryu_firmware"] = [ self.embed["emu_info"]["ryu_firmware"] = [
line.split()[-1] line.split()[-1]
for line in log_file.splitlines() for line in log_file.splitlines()
if "Firmware Version:" in line if "Firmware Version:" in line
][0] ][0]
except (AttributeError, IndexError): except (AttributeError, IndexError):
pass continue
def format_log_embed(): def format_log_embed():
cleaned_game_name = re.sub( cleaned_game_name = re.sub(
@ -181,6 +201,11 @@ class LogFileReader(Cog):
5) Upload the latest log file.""", 5) Upload the latest log file.""",
inline=False, inline=False,
) )
log_embed.add_field(
name="Latest Error Snippet",
value=self.embed["game_info"]["errors"],
inline=False,
)
else: else:
log_embed.add_field( log_embed.add_field(
name="Latest Error Snippet", name="Latest Error Snippet",
@ -226,7 +251,7 @@ class LogFileReader(Cog):
"-1": "Custom", "-1": "Custom",
"1": "Native (720p/1080p)", "1": "Native (720p/1080p)",
"2": "2x (1440p/2160p)", "2": "2x (1440p/2160p)",
"3": "3x (2160p/31240p)", "3": "3x (2160p/3240p)",
"4": "4x (2880p/4320p)", "4": "4x (2880p/4320p)",
} }
setting[name] = resolution_map[setting_value] setting[name] = resolution_map[setting_value]
@ -304,41 +329,69 @@ class LogFileReader(Cog):
elif line[0] == " " or line == "": elif line[0] == " " or line == "":
curr_error_lines.append(line) curr_error_lines.append(line)
def error_search(search_term): def error_search(search_terms):
found_term = bool( for term in search_terms:
for error_lines in errors:
line = "\n".join(error_lines)
if term in line:
return True
return False
shader_cache_collision = error_search(["Cache collision found"])
dump_hash_warning = error_search(["ResultFsInvalidIvfcHash"])
shader_cache_corruption = error_search(
[ [
line """Object reference not set to an instance of an object.
for line in errors at Ryujinx.Graphics.Gpu.Shader.ShaderCache.Initialize()""",
if any(search_term in string for string in line) "System.IO.InvalidDataException: End of Central Directory record could not be found",
] ]
) )
return found_term
shader_cache_collision = error_search("Cache collision found")
dump_hash_warning = error_search("ResultFsInvalidIvfcHash")
last_errors = "\n".join( last_errors = "\n".join(
errors[-1][:2] if "|E|" in errors[-1][0] else "" errors[-1][:2] if "|E|" in errors[-1][0] else ""
) )
except IndexError: except IndexError:
last_errors = None last_errors = None
return (last_errors, shader_cache_collision, dump_hash_warning) return (
last_errors,
shader_cache_collision,
dump_hash_warning,
shader_cache_corruption,
)
# Finds the lastest error denoted by |E| in the log and its first line # Finds the lastest error denoted by |E| in the log and its first line
# Also warns of shader cache collisions # Also warns of common issues
( (
last_error_snippet, last_error_snippet,
shader_cache_warn, shader_cache_warn,
dump_hash_warning, dump_hash_warning,
shader_cache_corruption_warn,
) = analyse_error_message() ) = analyse_error_message()
if last_error_snippet: if last_error_snippet:
self.embed["game_info"]["errors"] = f"```{last_error_snippet}```" self.embed["game_info"]["errors"] = f"```{last_error_snippet}```"
else: else:
pass pass
# Game name parsed last so that user settings are visible with empty log
self.embed["game_info"]["game_name"] = (
re.search(
r"Loader LoadNca: Application Loaded:\s([^;\n\r]*)",
log_file,
re.MULTILINE,
)
.group(1)
.rstrip()
)
if shader_cache_warn: if shader_cache_warn:
shader_cache_warn = f"⚠️ Cache collision detected. Investigate possible shader cache issues" shader_cache_warn = f"⚠️ Cache collision detected. Investigate possible shader cache issues"
self.embed["game_info"]["notes"].append(shader_cache_warn) self.embed["game_info"]["notes"].append(shader_cache_warn)
if shader_cache_corruption_warn:
shader_cache_corruption_warn = f"⚠️ Cache corruption detected. Investigate possible shader cache issues"
self.embed["game_info"]["notes"].append(
shader_cache_corruption_warn
)
if dump_hash_warning: if dump_hash_warning:
dump_hash_warning = f"⚠️ Dump error detected. Investigate possible bad game/firmware dump issues" dump_hash_warning = f"⚠️ Dump error detected. Investigate possible bad game/firmware dump issues"
self.embed["game_info"]["notes"].append(dump_hash_warning) self.embed["game_info"]["notes"].append(dump_hash_warning)