From 0cc7f3585f38e80110c272dcb5fef3ef850dd5b1 Mon Sep 17 00:00:00 2001 From: Andy Herrick Date: Wed, 13 May 2020 16:05:02 -0400 Subject: [PATCH] 8244576: [macos] Volume icon deleted by osascript for background image Reviewed-by: asemenyuk, almatvee --- .../jpackage/internal/MacDmgBundler.java | 33 +++++++++---------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacDmgBundler.java b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacDmgBundler.java index 81de7f34743..78c0b8ff2da 100644 --- a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacDmgBundler.java +++ b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacDmgBundler.java @@ -310,19 +310,29 @@ public class MacDmgBundler extends MacBaseInstallerBundler { File mountedRoot = new File(imagesRoot.getAbsolutePath(), APP_NAME.fetchFrom(params)); - try { - // volume icon - File volumeIconFile = new File(mountedRoot, ".VolumeIcon.icns"); - IOUtils.copyFile(getConfig_VolumeIcon(params), - volumeIconFile); - // background image File bgdir = new File(mountedRoot, BACKGROUND_IMAGE_FOLDER); bgdir.mkdirs(); IOUtils.copyFile(getConfig_VolumeBackground(params), new File(bgdir, BACKGROUND_IMAGE)); + // We will not consider setting background image and creating link + // to install-dir in DMG as critical error, since it can fail in + // headless enviroment. + try { + pb = new ProcessBuilder("osascript", + getConfig_VolumeScript(params).getAbsolutePath()); + IOUtils.exec(pb); + } catch (IOException ex) { + Log.verbose(ex); + } + + // volume icon + File volumeIconFile = new File(mountedRoot, ".VolumeIcon.icns"); + IOUtils.copyFile(getConfig_VolumeIcon(params), + volumeIconFile); + // Indicate that we want a custom icon // NB: attributes of the root directory are ignored // when creating the volume @@ -356,16 +366,6 @@ public class MacDmgBundler extends MacBaseInstallerBundler { Log.verbose(I18N.getString("message.setfile.dmg")); } - // We will not consider setting background image and creating link to - // /Application folder in DMG as critical error, since it can fail in - // headless enviroment. - try { - pb = new ProcessBuilder("osascript", - getConfig_VolumeScript(params).getAbsolutePath()); - IOUtils.exec(pb); - } catch (IOException ex) { - Log.verbose(ex); - } } finally { // Detach the temporary image pb = new ProcessBuilder( @@ -493,5 +493,4 @@ public class MacDmgBundler extends MacBaseInstallerBundler { public boolean isDefault() { return true; } - }