From 8f09cce173d675512d053988a91b9450c2268bb8 Mon Sep 17 00:00:00 2001 From: Saptarshi Sarkar Date: Fri, 16 Feb 2024 17:11:02 +0530 Subject: [PATCH] fix: Fixed app name in macos --- GUI/src/main/java/ui/UIController.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/GUI/src/main/java/ui/UIController.java b/GUI/src/main/java/ui/UIController.java index 813b114ad..a6817b1ab 100644 --- a/GUI/src/main/java/ui/UIController.java +++ b/GUI/src/main/java/ui/UIController.java @@ -102,7 +102,8 @@ private void downloadUpdate() { File currentExecutable = currentExecutablePath.toFile(); String customDirectory = getDir(); Path tmpFolder = Files.createTempDirectory("Drifty").toAbsolutePath(); - Job updateJob = new Job(Constants.updateURL.toString(), tmpFolder.toString(), currentExecutablePath.getFileName().toString(), false); + String latestExecutableName = OS.isMac() ? "Drifty_GUI.pkg" : currentExecutable.getName(); + Job updateJob = new Job(Constants.updateURL.toString(), tmpFolder.toString(), latestExecutableName, false); addJob(updateJob); Thread downloadUpdate = new Thread(batchDownloader()); downloadUpdate.start(); @@ -112,13 +113,13 @@ private void downloadUpdate() { setDir(customDirectory); if (OS.isMac()) { try { - File pkg = new File(tmpFolder.toString(), currentExecutablePath.getFileName().toString()); + File pkg = new File(tmpFolder.toString(), latestExecutableName); boolean isExecutable = pkg.setExecutable(true); if (!isExecutable) { M.msgUpdateError("Failed to set the pkg file as executable!"); new ConfirmationDialog("Update Failed", "Failed to set the pkg file as executable!", true, true).getResponse(); } - String argument = Paths.get(tmpFolder.toString(), currentExecutablePath.getFileName().toString()).toAbsolutePath().toString(); + String argument = Paths.get(tmpFolder.toString(), latestExecutableName).toAbsolutePath().toString(); // new ConfirmationDialog("PKG start command", "The command is " + nl.repeat(2) + "open" + argument).getResponse(); // M.msgUpdateInfo("The command is " + nl.repeat(2) + "open" + argument); new ProcBuilder("open").withArgs(argument).withNoTimeout().ignoreExitStatus().run();