mirror of
https://github.com/Ryujinx/ryuko-ng.git
synced 2025-01-18 14:47:19 +00:00
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:
parent
d1c536e792
commit
da9ea20a9d
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue