diff --git a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacBaseInstallerBundler.java b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacBaseInstallerBundler.java index 6423ea12268..d55c1da9a58 100644 --- a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacBaseInstallerBundler.java +++ b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacBaseInstallerBundler.java @@ -83,6 +83,17 @@ public abstract class MacBaseInstallerBundler extends AbstractBundler { params -> "", null); + public static final BundlerParamInfo MAC_INSTALL_DIR = + new StandardBundlerParam<>( + "mac-install-dir", + String.class, + params -> { + String dir = INSTALL_DIR.fetchFrom(params); + return (dir != null) ? dir : "/Applications"; + }, + (s, p) -> s + ); + public static final BundlerParamInfo INSTALLER_NAME = new StandardBundlerParam<> ( "mac.installerName", 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 fd0ca2f604a..81de7f34743 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 @@ -31,6 +31,7 @@ import java.nio.file.Path; import java.text.MessageFormat; import java.util.*; import static jdk.incubator.jpackage.internal.MacAppImageBuilder.ICON_ICNS; +import static jdk.incubator.jpackage.internal.MacAppImageBuilder.MAC_CF_BUNDLE_IDENTIFIER; import static jdk.incubator.jpackage.internal.OverridableResource.createResource; import static jdk.incubator.jpackage.internal.StandardBundlerParam.*; @@ -116,8 +117,8 @@ public class MacDmgBundler extends MacBaseInstallerBundler { data.put("DEPLOY_VOLUME_PATH", volumePath.toString()); data.put("DEPLOY_APPLICATION_NAME", APP_NAME.fetchFrom(params)); - data.put("DEPLOY_INSTALL_LOCATION", "(path to applications folder)"); - data.put("DEPLOY_INSTALL_NAME", "Applications"); + data.put("DEPLOY_INSTALL_LOCATION", MAC_INSTALL_DIR.fetchFrom(params)); + data.put("DEPLOY_INSTALL_NAME", MAC_INSTALL_DIR.fetchFrom(params)); createResource(DEFAULT_DMG_SETUP_SCRIPT, params) .setCategory(I18N.getString("resource.dmg-setup-script")) diff --git a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacPkgBundler.java b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacPkgBundler.java index 8bf6e96b119..dae6c96ef15 100644 --- a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacPkgBundler.java +++ b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/MacPkgBundler.java @@ -101,17 +101,6 @@ public class MacPkgBundler extends MacBaseInstallerBundler { }, (s, p) -> s); - public static final BundlerParamInfo MAC_INSTALL_DIR = - new StandardBundlerParam<>( - "mac-install-dir", - String.class, - params -> { - String dir = INSTALL_DIR.fetchFrom(params); - return (dir != null) ? dir : "/Applications"; - }, - (s, p) -> s - ); - public static final BundlerParamInfo INSTALLER_SUFFIX = new StandardBundlerParam<> ( "mac.pkg.installerName.suffix", diff --git a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/resources/DMGsetup.scpt b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/resources/DMGsetup.scpt index eac9c6daf76..4f0b23857c2 100644 --- a/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/resources/DMGsetup.scpt +++ b/src/jdk.incubator.jpackage/macosx/classes/jdk/incubator/jpackage/internal/resources/DMGsetup.scpt @@ -17,7 +17,7 @@ tell application "Finder" set background picture of theViewOptions to POSIX file "DEPLOY_BG_FILE" -- Create alias for install location - make new alias file at POSIX file "DEPLOY_VOLUME_PATH" to DEPLOY_INSTALL_LOCATION with properties {name:"DEPLOY_INSTALL_NAME"} + make new alias file at POSIX file "DEPLOY_VOLUME_PATH" to POSIX file "DEPLOY_INSTALL_LOCATION" with properties {name:"DEPLOY_INSTALL_NAME"} set allTheFiles to the name of every item of theWindow repeat with theFile in allTheFiles @@ -25,7 +25,7 @@ tell application "Finder" if theFilePath is "/DEPLOY_APPLICATION_NAME.app" then -- Position application location set position of item theFile of theWindow to {120, 130} - else if theFilePath is "/DEPLOY_INSTALL_NAME" then + else if theFilePath is "DEPLOY_INSTALL_NAME" then -- Position install location set position of item theFile of theWindow to {390, 130} else