mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	Undertale: Fixed output location of the patched game in UndertaleClient.py (#3418)
* Update UndertaleClient.py Fixed output location of the patched game Fixed the error that when the client is opened outside of the archipelago folder, the patched folder would be created in there which on windows ends up trying to create it in the system32 folder Bug Report: https://discord.com/channels/731205301247803413/1148330675452264499/1237412436382973962 * Undertale: removed unnecessary wrapping in UndertaleClient.py I did not know os.path.join was unnecessary in this case the more you know.
This commit is contained in:
		| @@ -29,7 +29,7 @@ class UndertaleCommandProcessor(ClientCommandProcessor): | |||||||
|     def _cmd_patch(self): |     def _cmd_patch(self): | ||||||
|         """Patch the game. Only use this command if /auto_patch fails.""" |         """Patch the game. Only use this command if /auto_patch fails.""" | ||||||
|         if isinstance(self.ctx, UndertaleContext): |         if isinstance(self.ctx, UndertaleContext): | ||||||
|             os.makedirs(name=os.path.join(os.getcwd(), "Undertale"), exist_ok=True) |             os.makedirs(name=Utils.user_path("Undertale"), exist_ok=True) | ||||||
|             self.ctx.patch_game() |             self.ctx.patch_game() | ||||||
|             self.output("Patched.") |             self.output("Patched.") | ||||||
|  |  | ||||||
| @@ -43,7 +43,7 @@ class UndertaleCommandProcessor(ClientCommandProcessor): | |||||||
|     def _cmd_auto_patch(self, steaminstall: typing.Optional[str] = None): |     def _cmd_auto_patch(self, steaminstall: typing.Optional[str] = None): | ||||||
|         """Patch the game automatically.""" |         """Patch the game automatically.""" | ||||||
|         if isinstance(self.ctx, UndertaleContext): |         if isinstance(self.ctx, UndertaleContext): | ||||||
|             os.makedirs(name=os.path.join(os.getcwd(), "Undertale"), exist_ok=True) |             os.makedirs(name=Utils.user_path("Undertale"), exist_ok=True) | ||||||
|             tempInstall = steaminstall |             tempInstall = steaminstall | ||||||
|             if not os.path.isfile(os.path.join(tempInstall, "data.win")): |             if not os.path.isfile(os.path.join(tempInstall, "data.win")): | ||||||
|                 tempInstall = None |                 tempInstall = None | ||||||
| @@ -62,7 +62,7 @@ class UndertaleCommandProcessor(ClientCommandProcessor): | |||||||
|                 for file_name in os.listdir(tempInstall): |                 for file_name in os.listdir(tempInstall): | ||||||
|                     if file_name != "steam_api.dll": |                     if file_name != "steam_api.dll": | ||||||
|                         shutil.copy(os.path.join(tempInstall, file_name), |                         shutil.copy(os.path.join(tempInstall, file_name), | ||||||
|                                os.path.join(os.getcwd(), "Undertale", file_name)) |                                Utils.user_path("Undertale", file_name)) | ||||||
|                 self.ctx.patch_game() |                 self.ctx.patch_game() | ||||||
|                 self.output("Patching successful!") |                 self.output("Patching successful!") | ||||||
|  |  | ||||||
| @@ -111,12 +111,12 @@ class UndertaleContext(CommonContext): | |||||||
|         self.save_game_folder = os.path.expandvars(r"%localappdata%/UNDERTALE") |         self.save_game_folder = os.path.expandvars(r"%localappdata%/UNDERTALE") | ||||||
|  |  | ||||||
|     def patch_game(self): |     def patch_game(self): | ||||||
|         with open(os.path.join(os.getcwd(), "Undertale", "data.win"), "rb") as f: |         with open(Utils.user_path("Undertale", "data.win"), "rb") as f: | ||||||
|             patchedFile = bsdiff4.patch(f.read(), undertale.data_path("patch.bsdiff")) |             patchedFile = bsdiff4.patch(f.read(), undertale.data_path("patch.bsdiff")) | ||||||
|         with open(os.path.join(os.getcwd(), "Undertale", "data.win"), "wb") as f: |         with open(Utils.user_path("Undertale", "data.win"), "wb") as f: | ||||||
|             f.write(patchedFile) |             f.write(patchedFile) | ||||||
|         os.makedirs(name=os.path.join(os.getcwd(), "Undertale", "Custom Sprites"), exist_ok=True) |         os.makedirs(name=Utils.user_path("Undertale", "Custom Sprites"), exist_ok=True) | ||||||
|         with open(os.path.expandvars(os.path.join(os.getcwd(), "Undertale", "Custom Sprites", |         with open(os.path.expandvars(Utils.user_path("Undertale", "Custom Sprites", | ||||||
|                                      "Which Character.txt")), "w") as f: |                                      "Which Character.txt")), "w") as f: | ||||||
|             f.writelines(["// Put the folder name of the sprites you want to play as, make sure it is the only " |             f.writelines(["// Put the folder name of the sprites you want to play as, make sure it is the only " | ||||||
|                           "line other than this one.\n", "frisk"]) |                           "line other than this one.\n", "frisk"]) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 dennisw100
					dennisw100