From 7be585949b0d765624ee2a38648c8e44a524813a Mon Sep 17 00:00:00 2001 From: jamesbrq Date: Sat, 18 May 2024 16:26:50 -0400 Subject: [PATCH] MLSS: General bugfixes + Add patch extension to inno_setup.iss (#3286) * Remove outdated header change for ROM verification * Update Connections to be compatible with python ver. 3.8 * Update inno_setup.iss * Update inno_setup.iss --- inno_setup.iss | 5 +++++ worlds/mlss/Client.py | 15 +++------------ worlds/mlss/Regions.py | 7 ++----- worlds/mlss/Rom.py | 3 --- worlds/mlss/data/basepatch.bsdiff | Bin 17619 -> 17615 bytes 5 files changed, 10 insertions(+), 20 deletions(-) diff --git a/inno_setup.iss b/inno_setup.iss index 529a96a33ac6..4b37279e8de0 100644 --- a/inno_setup.iss +++ b/inno_setup.iss @@ -169,6 +169,11 @@ Root: HKCR; Subkey: "{#MyAppName}pkmnepatch"; ValueData: "Ar Root: HKCR; Subkey: "{#MyAppName}pkmnepatch\DefaultIcon"; ValueData: "{app}\ArchipelagoBizHawkClient.exe,0"; ValueType: string; ValueName: ""; Root: HKCR; Subkey: "{#MyAppName}pkmnepatch\shell\open\command"; ValueData: """{app}\ArchipelagoBizHawkClient.exe"" ""%1"""; ValueType: string; ValueName: ""; +Root: HKCR; Subkey: ".apmlss"; ValueData: "{#MyAppName}mlsspatch"; Flags: uninsdeletevalue; ValueType: string; ValueName: ""; +Root: HKCR; Subkey: "{#MyAppName}mlsspatch"; ValueData: "Archipelago Mario & Luigi Superstar Saga Patch"; Flags: uninsdeletekey; ValueType: string; ValueName: ""; +Root: HKCR; Subkey: "{#MyAppName}mlsspatch\DefaultIcon"; ValueData: "{app}\ArchipelagoBizHawkClient.exe,0"; ValueType: string; ValueName: ""; +Root: HKCR; Subkey: "{#MyAppName}mlsspatch\shell\open\command"; ValueData: """{app}\ArchipelagoBizHawkClient.exe"" ""%1"""; ValueType: string; ValueName: ""; + Root: HKCR; Subkey: ".apcv64"; ValueData: "{#MyAppName}cv64patch"; Flags: uninsdeletevalue; ValueType: string; ValueName: ""; Root: HKCR; Subkey: "{#MyAppName}cv64patch"; ValueData: "Archipelago Castlevania 64 Patch"; Flags: uninsdeletekey; ValueType: string; ValueName: ""; Root: HKCR; Subkey: "{#MyAppName}cv64patch\DefaultIcon"; ValueData: "{app}\ArchipelagoBizHawkClient.exe,0"; ValueType: string; ValueName: ""; diff --git a/worlds/mlss/Client.py b/worlds/mlss/Client.py index 322f243ceb00..a1cd43afbae8 100644 --- a/worlds/mlss/Client.py +++ b/worlds/mlss/Client.py @@ -47,19 +47,10 @@ async def validate_rom(self, ctx: "BizHawkClientContext") -> bool: # Check ROM name/patch version rom_name_bytes = await bizhawk.read(ctx.bizhawk_ctx, [(0xA0, 14, "ROM")]) rom_name = bytes([byte for byte in rom_name_bytes[0] if byte != 0]).decode("UTF-8") - if not rom_name.startswith("MARIO&LUIGIU"): - return False - if rom_name == "MARIO&LUIGIUA8": - logger.info( - "ERROR: You appear to be running an unpatched version of Mario & Luigi Superstar Saga. " - "You need to generate a patch file and use it to create a patched ROM." - ) - return False - if rom_name != "MARIO&LUIGIUAP": + if not rom_name.startswith("MARIO&LUIGIUA8"): logger.info( - "ERROR: The patch file used to create this ROM is not compatible with " - "this client. Double check your client version against the version being " - "used by the generator." + "ERROR: You have opened a game that is not Mario & Luigi Superstar Saga. " + "Please make sure you are opening the correct ROM." ) return False except UnicodeDecodeError: diff --git a/worlds/mlss/Regions.py b/worlds/mlss/Regions.py index be1c5d1063ae..992e99e2c7f7 100644 --- a/worlds/mlss/Regions.py +++ b/worlds/mlss/Regions.py @@ -299,7 +299,7 @@ def connect( target: str, rule: typing.Optional[typing.Callable] = None, reach: typing.Optional[bool] = False, -) -> Entrance | None: +) -> typing.Optional[Entrance]: source_region = world.multiworld.get_region(source, world.player) target_region = world.multiworld.get_region(target, world.player) @@ -317,7 +317,4 @@ def connect( source_region.exits.append(connection) connection.connect(target_region) - if reach: - return connection - else: - return None + return connection if reach else None diff --git a/worlds/mlss/Rom.py b/worlds/mlss/Rom.py index 1b8a182509ae..08921500dacb 100644 --- a/worlds/mlss/Rom.py +++ b/worlds/mlss/Rom.py @@ -272,9 +272,6 @@ def write_tokens(world: "MLSSWorld", patch: MLSSProcedurePatch) -> None: # Bake seed name into ROM patch.write_token(APTokenTypes.WRITE, 0xDF00A0, world.multiworld.seed_name.encode("UTF-8")) - # Bake patch into header - patch.write_token(APTokenTypes.WRITE, 0xAD, "P".encode("UTF-8")) - # Intro Skip patch.write_token( APTokenTypes.WRITE, diff --git a/worlds/mlss/data/basepatch.bsdiff b/worlds/mlss/data/basepatch.bsdiff index 45ed6a6b724fda04f43c17471aa42db1f2eabab3..156d28f346e8fa38fb2d1c4a3ce1b9e01342e848 100644 GIT binary patch delta 5219 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 delta 5242 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 AIRF3v