[gimp-macos-build] Use create-dmg tool to create DMG



commit 2be817e81b61c5bbfaa9e21462142a07f55cee56
Author: Oleksii Samorukov <oleksii_samorukov mckinsey com>
Date:   Wed Oct 30 11:49:28 2019 +0100

    Use create-dmg tool to create DMG

 README.md                                       |   2 +-
 package/build.sh                                |  21 +-
 package/create-dmg/.gitignore                   |   4 +
 package/create-dmg/LICENSE                      |  21 ++
 package/create-dmg/README.md                    |  96 ++++++
 package/create-dmg/builder/create-dmg.builder   |  26 ++
 package/create-dmg/create-dmg                   | 422 ++++++++++++++++++++++++
 package/create-dmg/sample                       |  18 +
 package/create-dmg/support/brew-me.sh           |  21 ++
 package/create-dmg/support/dmg-license.py       | 163 +++++++++
 package/create-dmg/support/template.applescript |  74 +++++
 package/gimp-dmg.png                            | Bin 0 -> 36638 bytes
 package/test.sh                                 |  18 +
 13 files changed, 884 insertions(+), 2 deletions(-)
---
diff --git a/README.md b/README.md
index 4041e99..a346aa3 100644
--- a/README.md
+++ b/README.md
@@ -33,7 +33,7 @@ I was able to get working builds in the VirtualBox VM, it works stable enough fo
   - fixing pixmap and imm cache files to remove absolute pathnames
   - compiles all py files to pyc to avoid writes to the Application folders
   - Signing all binaries
-  - Creating DMG package and signing it
+  - Creating DMG package using [create-dmg](https://github.com/andreyvit/create-dmg) tool and signing it
 - Uploading DMG to the CircleCI build artifacts
 
 ## Branches
diff --git a/package/build.sh b/package/build.sh
index 924e052..5958456 100755
--- a/package/build.sh
+++ b/package/build.sh
@@ -94,7 +94,7 @@ popd
 echo "copy xdg-email wrapper to the package"
 cp xdg-email ${PACKAGE_DIR}/GIMP-2.10.app/Contents/MacOS
 
-echo "copy pygimp.interp wrapper to the package"
+echo "copy pygimp.interp to the package"
 mkdir -p ${PACKAGE_DIR}/GIMP-2.10.app/Contents/Resources/lib/gimp/2.0/interpreters
 cp pygimp.interp ${PACKAGE_DIR}/GIMP-2.10.app/Contents/Resources/lib/gimp/2.0/interpreters
 
@@ -125,6 +125,25 @@ fi
 mkdir -p /tmp/artifacts/
 rm -f /tmp/tmp.dmg
 rm -f "gimp-${GIMP_VERSION}-x86_64.dmg"
+
+cd create-dmg
+
+./create-dmg \
+--volname "GIMP 2.10 Install" \
+--volicon "/Applications/GIMP-2.10.app/Contents/Resources/gimp.icns" \
+--background "../gimp-dmg.png" \
+--window-pos 1 1 \
+--icon "GIMP-2.10.app" 190 360 \
+--window-size 640 480 \
+--icon-size 110 \
+--icon "Applications" 110 110 \
+--hide-extension "Applications" \
+--app-drop-link 450 360 \
+--format UDBZ \
+"/tmp/artifacts/${DMGNAME}" \
+"$PACKAGE_DIR/"
+cd ..
+
 hdiutil create /tmp/tmp.dmg -ov -volname "GIMP 2.10 Install" -fs HFS+ -srcfolder "$PACKAGE_DIR/"
 hdiutil convert /tmp/tmp.dmg -format UDBZ -o "/tmp/artifacts/${DMGNAME}"
 
diff --git a/package/create-dmg/.gitignore b/package/create-dmg/.gitignore
new file mode 100644
index 0000000..e6cf196
--- /dev/null
+++ b/package/create-dmg/.gitignore
@@ -0,0 +1,4 @@
+.svn
+
+*.dmg
+.DS_Store
diff --git a/package/create-dmg/LICENSE b/package/create-dmg/LICENSE
new file mode 100644
index 0000000..349b6d8
--- /dev/null
+++ b/package/create-dmg/LICENSE
@@ -0,0 +1,21 @@
+The MIT License (MIT)
+
+Copyright (c) 2008-2014 Andrey Tarantsov
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/package/create-dmg/README.md b/package/create-dmg/README.md
new file mode 100644
index 0000000..495f306
--- /dev/null
+++ b/package/create-dmg/README.md
@@ -0,0 +1,96 @@
+create-dmg
+==========
+
+A shell script to build fancy DMGs.
+
+
+Status and contribution policy
+------------------------------
+
+This project is maintained thanks to the contributors who send pull requests, and now (Sep 2018) with the 
help of [@aonez](https://github.com/aonez).
+
+We will merge any pull request that adds something useful and does not break existing things, and will often 
grant commit access to the repository.
+
+If you're an active user and want to be a maintainer, or just want to chat, please ping us at 
[gitter.im/create-dmg/Lobby](https://gitter.im/create-dmg/Lobby).
+
+
+Installation
+------------
+
+- You can install this script using [Homebrew](https://brew.sh):
+
+  ```sh
+  brew install create-dmg
+  ```
+
+- You can download the [latest release](https://github.com/andreyvit/create-dmg/releases/latest)
+
+- You can also clone the entire repository:
+
+  ```sh
+  git clone https://github.com/andreyvit/create-dmg.git
+  ```
+
+Usage
+-----
+
+```sh
+create-dmg [options...] [output\_name.dmg] [source\_folder]
+```
+
+All contents of source\_folder will be copied into the disk image.
+
+**Options:**
+
+*   **--volname [name]:** set volume name (displayed in the Finder sidebar and window title)
+*   **--volicon [icon.icns]:** set volume icon
+*   **--background [pic.png]:** set folder background image (provide png, gif, jpg)
+*   **--window-pos [x y]:** set position the folder window
+*   **--window-size [width height]:** set size of the folder window
+*   **--text-size [text size]:** set window text size (10-16)
+*   **--icon-size [icon size]:** set window icons size (up to 128)
+*   **--icon [file name] [x y]:** set position of the file's icon
+*   **--hide-extension [file name]:** hide the extension of file
+*   **--custom-icon [file name]/[custom icon]/[sample file] [x y]:** set position and custom icon
+*   **--app-drop-link [x y]:** make a drop link to Applications, at location x, y
+*   **--ql-drop-link [x y]:** make a drop link to /Library/QuickLook, at location x, y
+*   **--eula [eula file]:** attach a license file to the dmg
+*   **--rez [rez path]:** specify custom path to Rez tool used to include license file
+*   **--no-internet-enable:** disable automatic mount&copy
+*   **--format:** specify the final image format (default is UDZO)
+*   **--add-file [target name] [path to source file] [x y]:** add additional file (option can be used 
multiple times)
+*   **--add-folder [target name] [path to source folder] [x y]:** add additional folder (option can be used 
multiple times)
+*   **--disk-image-size [x]:** set the disk image size manually to x MB
+*   **--hdiutil-verbose:** execute hdiutil in verbose mode
+*   **--hdiutil-quiet:** execute hdiutil in quiet mode
+*   **--sandbox-safe:** execute hdiutil with sandbox compatibility and don not bless
+*   **--version:** show tool version number
+*   **-h, --help:** display the help
+
+
+Example
+-------
+
+```sh
+#!/bin/sh
+test -f Application-Installer.dmg && rm Application-Installer.dmg
+create-dmg \
+--volname "Application Installer" \
+--volicon "application\_icon.icns" \
+--background "installer\_background.png" \
+--window-pos 200 120 \
+--window-size 800 400 \
+--icon-size 100 \
+--icon "Application.app" 200 190 \
+--hide-extension "Application.app" \
+--app-drop-link 600 185 \
+"Application-Installer.dmg" \
+"source_folder/"
+```
+
+Alternatives
+------------
+
+* [node-appdmg](https://github.com/LinusU/node-appdmg)
+* [dmgbuild](https://pypi.python.org/pypi/dmgbuild)
+* see the [StackOverflow 
question](http://stackoverflow.com/questions/96882/how-do-i-create-a-nice-looking-dmg-for-mac-os-x-using-command-line-tools)
diff --git a/package/create-dmg/builder/create-dmg.builder b/package/create-dmg/builder/create-dmg.builder
new file mode 100644
index 0000000..d428528
--- /dev/null
+++ b/package/create-dmg/builder/create-dmg.builder
@@ -0,0 +1,26 @@
+SET    app_name        create-dmg
+
+VERSION        create-dmg.cur  create-dmg      heads/master
+
+NEWDIR build.dir       temp    %-build -
+
+NEWFILE        create-dmg.zip  featured        %.zip   %
+
+
+COPYTO [build.dir]
+       INTO    create-dmg      [create-dmg.cur]/create-dmg
+       INTO    sample  [create-dmg.cur]/sample
+       INTO    support [create-dmg.cur]/support
+       
+SUBSTVARS      [build.dir<alter>]/create-dmg   [[]]
+
+
+ZIP    [create-dmg.zip]
+       INTO    [build-files-prefix]    [build.dir]
+
+
+PUT    megabox-builds  create-dmg.zip
+PUT    megabox-builds  build.log
+
+PUT    s3-builds       create-dmg.zip
+PUT    s3-builds       build.log
diff --git a/package/create-dmg/create-dmg b/package/create-dmg/create-dmg
new file mode 100755
index 0000000..299b01f
--- /dev/null
+++ b/package/create-dmg/create-dmg
@@ -0,0 +1,422 @@
+#!/bin/bash
+
+# Create a read-only disk image of the contents of a folder
+
+set -e;
+
+function pure_version() {
+       echo '1.0.0.6'
+}
+
+function version() {
+       echo "create-dmg $(pure_version)"
+}
+
+function usage() {
+       version
+       echo "Creates a fancy DMG file."
+       echo "Usage:  $(basename $0) [options] <output_name.dmg> <source_folder>"
+       echo "All contents of source_folder will be copied into the disk image."
+       echo "Options:"
+       echo "  --volname name"
+       echo "      set volume name (displayed in the Finder sidebar and window title)"
+       echo "  --volicon icon.icns"
+       echo "      set volume icon"
+       echo "  --background pic.png"
+       echo "      set folder background image (provide png, gif, jpg)"
+       echo "  --window-pos x y"
+       echo "      set position the folder window"
+       echo "  --window-size width height"
+       echo "      set size of the folder window"
+       echo "  --text-size text_size"
+       echo "      set window text size (10-16)"
+       echo "  --icon-size icon_size"
+       echo "      set window icons size (up to 128)"
+       echo "  --icon file_name x y"
+       echo "      set position of the file's icon"
+       echo "  --hide-extension file_name"
+       echo "      hide the extension of file"
+       echo "  --custom-icon file_name custom_icon_or_sample_file x y"
+       echo "      set position and custom icon"
+       echo "  --app-drop-link x y"
+       echo "      make a drop link to Applications, at location x,y"
+       echo "  --ql-drop-link x y"
+       echo "      make a drop link to user QuickLook install dir, at location x,y"
+       echo "  --eula eula_file"
+       echo "      attach a license file to the dmg"
+       echo "  --no-internet-enable"
+       echo "      disable automatic mount&copy"
+       echo "  --format"
+       echo "      specify the final image format (default is UDZO)"
+       echo "  --add-file target_name path_to_source_file x y"
+       echo "      add additional file (option can be used multiple times)"
+       echo "  --add-folder target_name path_to_source_folder x y"
+       echo "      add additional folder (option can be used multiple times)"
+       echo "  --disk-image-size x"
+       echo "      set the disk image size manually to x MB"
+       echo "  --hdiutil-verbose"
+       echo "      execute hdiutil in verbose mode"  
+       echo "  --hdiutil-quiet"
+       echo "      execute hdiutil in quiet mode"
+       echo "  --sandbox-safe"
+       echo "      execute hdiutil with sandbox compatibility and do not bless"
+       echo "  --rez rez_path"
+       echo "      use custom path to Rez tool"
+       echo "  --version         show tool version number"
+       echo "  -h, --help        display this help"
+       exit 0
+}
+
+WINX=10
+WINY=60
+WINW=500
+WINH=350
+ICON_SIZE=128
+TEXT_SIZE=16
+FORMAT="UDZO"
+ADD_FILE_SOURCES=()
+ADD_FILE_TARGETS=()
+ADD_FOLDER_SOURCES=()
+ADD_FOLDER_TARGETS=()
+IMAGEKEY=""
+HDIUTIL_VERBOSITY=""
+SANDBOX_SAFE=0
+SKIP_JENKINS=0
+
+while test "${1:0:1}" = "-"; do
+       case $1 in
+       --volname)
+               VOLUME_NAME="$2"
+               shift; shift;;
+       --volicon)
+               VOLUME_ICON_FILE="$2"
+               shift; shift;;
+       --background)
+               BACKGROUND_FILE="$2"
+               BACKGROUND_FILE_NAME="$(basename $BACKGROUND_FILE)"
+               BACKGROUND_CLAUSE="set background picture of opts to file 
\".background:$BACKGROUND_FILE_NAME\""
+               REPOSITION_HIDDEN_FILES_CLAUSE="set position of every item to {theBottomRightX + 100, 100}"
+               shift; shift;;
+       --icon-size)
+               ICON_SIZE="$2"
+               shift; shift;;
+       --text-size)
+               TEXT_SIZE="$2"
+               shift; shift;;
+       --window-pos)
+               WINX=$2; WINY=$3
+               shift; shift; shift;;
+       --window-size)
+               WINW=$2; WINH=$3
+               shift; shift; shift;;
+       --icon)
+               POSITION_CLAUSE="${POSITION_CLAUSE}set position of item \"$2\" to {$3, $4}
+               "
+               shift; shift; shift; shift;;
+       --hide-extension)
+               HIDING_CLAUSE="${HIDING_CLAUSE}set the extension hidden of item \"$2\" to true
+               "
+               shift; shift;;
+       --custom-icon)
+               shift; shift; shift; shift; shift;;
+       -h | --help)
+               usage;;
+       --version)
+               version; exit 0;;
+       --pure-version)
+               pure_version; exit 0;;
+       --ql-drop-link)
+               QL_LINK=$2
+               QL_CLAUSE="set position of item \"QuickLook\" to {$2, $3}
+               "
+               shift; shift; shift;;
+       --app-drop-link)
+               APPLICATION_LINK=$2
+               APPLICATION_CLAUSE="set position of item \"Applications\" to {$2, $3}
+               "
+               shift; shift; shift;;
+       --eula)
+               EULA_RSRC=$2
+               shift; shift;;
+       --no-internet-enable)
+               NOINTERNET=1
+               shift;;
+       --format)
+               FORMAT="$2"
+               shift; shift;;
+       --add-file)
+               ADD_FILE_TARGETS+=("$2")
+               ADD_FILE_SOURCES+=("$3")
+               POSITION_CLAUSE="${POSITION_CLAUSE}
+               set position of item \"$2\" to {$4, $5}
+               "
+               shift; shift; shift; shift; shift;;
+       --add-folder)
+               ADD_FOLDER_TARGETS+=("$2")
+               ADD_FOLDER_SOURCES+=("$3")
+               POSITION_CLAUSE="${POSITION_CLAUSE}
+               set position of item \"$2\" to {$4, $5}
+               "
+               shift; shift; shift; shift; shift;;
+       --disk-image-size)
+               DISK_IMAGE_SIZE="$2"
+               shift; shift;;
+       --hdiutil-verbose)
+               HDIUTIL_VERBOSITY='-verbose'
+               shift;;
+       --hdiutil-quiet)
+               HDIUTIL_VERBOSITY='-quiet'
+               shift;; 
+       --sandbox-safe)
+               SANDBOX_SAFE=1
+               shift;; 
+       --rez)
+               REZ_PATH=$2
+               shift; shift;;
+       --skip-jenkins)
+               SKIP_JENKINS=1
+               shift;;
+       -*)
+               echo "Unknown option $1. Run with --help for help."
+               exit 1;;
+       esac
+       case $FORMAT in
+       UDZO)
+               IMAGEKEY="-imagekey zlib-level=9";;
+       UDBZ)
+               IMAGEKEY="-imagekey bzip2-level=9";;
+       esac
+done
+
+test -z "$2" && {
+       echo "Not enough arguments. Invoke with --help for help."
+       exit 1
+}
+
+SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
+DMG_PATH="$1"
+DMG_DIRNAME="$(dirname "$DMG_PATH")"
+DMG_DIR="$(cd "$DMG_DIRNAME" > /dev/null; pwd)"
+DMG_NAME="$(basename "$DMG_PATH")"
+DMG_TEMP_NAME="$DMG_DIR/rw.${DMG_NAME}"
+SRC_FOLDER="$(cd "$2" > /dev/null; pwd)"
+
+test -z "$VOLUME_NAME" && VOLUME_NAME="$(basename "$DMG_PATH" .dmg)"
+
+# brew formula will set this as 1 and embed the support scripts
+BREW_INSTALL=0
+
+AUX_PATH="$SCRIPT_DIR/support"
+
+if [ $BREW_INSTALL -eq 0 ]; then
+       test -d "$AUX_PATH" || {
+               echo "Cannot find support directory: $AUX_PATH"
+               exit 1
+       }
+fi
+
+if [ -f "$SRC_FOLDER/.DS_Store" ]; then
+       echo "Deleting any .DS_Store in source folder"
+       rm "$SRC_FOLDER/.DS_Store"
+fi
+
+# Create the image
+echo "Creating disk image..."
+test -f "${DMG_TEMP_NAME}" && rm -f "${DMG_TEMP_NAME}"
+
+# Using Megabytes since hdiutil fails with very large Byte numbers
+function blocks_to_megabytes() {
+       # Add 1 extra MB, since there's no decimal retention here
+       MB_SIZE=$((($1 * 512 / 1000 / 1000) + 1))
+       echo $MB_SIZE
+}
+
+function get_size() {
+       # Get block size in disk
+       bytes_size=`du -s "$1" | sed -e 's/     .*//g'`
+       echo `blocks_to_megabytes $bytes_size`
+}
+
+# Create the DMG with the specified size or the hdiutil estimation
+CUSTOM_SIZE=''
+if ! test -z "$DISK_IMAGE_SIZE"; then
+       CUSTOM_SIZE="-size ${DISK_IMAGE_SIZE}m"
+fi
+
+if [ $SANDBOX_SAFE -eq 0 ]; then
+       hdiutil create ${HDIUTIL_VERBOSITY} -srcfolder "$SRC_FOLDER" -volname "${VOLUME_NAME}" -fs HFS+ 
-fsargs "-c c=64,a=16,e=16" -format UDRW ${CUSTOM_SIZE} "${DMG_TEMP_NAME}"
+else   
+       hdiutil makehybrid ${HDIUTIL_VERBOSITY} -default-volume-name "${VOLUME_NAME}" -hfs -o 
"${DMG_TEMP_NAME}" "$SRC_FOLDER"
+       hdiutil convert -format UDRW -ov -o "${DMG_TEMP_NAME}" "${DMG_TEMP_NAME}"
+       DISK_IMAGE_SIZE_CUSTOM=$DISK_IMAGE_SIZE
+fi
+
+# Get the created DMG actual size
+DISK_IMAGE_SIZE=`get_size "${DMG_TEMP_NAME}"`
+
+# Use the custom size if bigger
+if [ $SANDBOX_SAFE -eq 1 ] && [ ! -z "$DISK_IMAGE_SIZE_CUSTOM" ] && [ $DISK_IMAGE_SIZE_CUSTOM -gt 
$DISK_IMAGE_SIZE ]; then
+       DISK_IMAGE_SIZE=$DISK_IMAGE_SIZE_CUSTOM
+fi
+
+# Estimate the additional soruces size
+if ! test -z "$ADD_FILE_SOURCES"; then
+       for i in "${!ADD_FILE_SOURCES[@]}"
+       do
+               SOURCE_SIZE=`get_size "${ADD_FILE_SOURCES[$i]}"`
+               DISK_IMAGE_SIZE=$(expr $DISK_IMAGE_SIZE + $SOURCE_SIZE)
+       done
+fi
+if ! test -z "$ADD_FOLDER_SOURCES"; then
+       for i in "${!ADD_FOLDER_SOURCES[@]}"
+       do
+               SOURCE_SIZE=`get_size "${ADD_FOLDER_SOURCES[$i]}"`
+               DISK_IMAGE_SIZE=$(expr $DISK_IMAGE_SIZE + $SOURCE_SIZE)
+       done
+fi
+
+# Add extra space for additional resources
+DISK_IMAGE_SIZE=$(expr $DISK_IMAGE_SIZE + 20)
+
+# Resize the image for the extra stuff
+hdiutil resize ${HDIUTIL_VERBOSITY} -size ${DISK_IMAGE_SIZE}m "${DMG_TEMP_NAME}"
+
+# mount it
+echo "Mounting disk image..."
+MOUNT_DIR="/Volumes/${VOLUME_NAME}"
+
+# try unmount dmg if it was mounted previously (e.g. developer mounted dmg, installed app and forgot to 
unmount it)
+echo "Unmounting disk image..."
+DEV_NAME=$(hdiutil info | egrep --color=never '^/dev/' | sed 1q | awk '{print $1}')
+test -d "${MOUNT_DIR}" && hdiutil detach "${DEV_NAME}"
+
+echo "Mount directory: $MOUNT_DIR"
+DEV_NAME=$(hdiutil attach -readwrite -noverify -noautoopen "${DMG_TEMP_NAME}" | egrep --color=never '^/dev/' 
| sed 1q | awk '{print $1}')
+echo "Device name:     $DEV_NAME"
+
+if ! test -z "$BACKGROUND_FILE"; then
+       echo "Copying background file..."
+       test -d "$MOUNT_DIR/.background" || mkdir "$MOUNT_DIR/.background"
+       cp "$BACKGROUND_FILE" "$MOUNT_DIR/.background/$BACKGROUND_FILE_NAME"
+fi
+
+if ! test -z "$APPLICATION_LINK"; then
+       echo "making link to Applications dir"
+       echo $MOUNT_DIR
+       ln -s /Applications "$MOUNT_DIR/Applications"
+fi
+
+if ! test -z "$QL_LINK"; then
+       echo "making link to QuickLook install dir"
+       echo $MOUNT_DIR
+       ln -s "/Library/QuickLook" "$MOUNT_DIR/QuickLook"
+fi
+
+if ! test -z "$VOLUME_ICON_FILE"; then
+       echo "Copying volume icon file '$VOLUME_ICON_FILE'..."
+       cp "$VOLUME_ICON_FILE" "$MOUNT_DIR/.VolumeIcon.icns"
+       SetFile -c icnC "$MOUNT_DIR/.VolumeIcon.icns"
+fi
+
+if ! test -z "$ADD_FILE_SOURCES"; then
+       echo "Copying custom files..."
+       for i in "${!ADD_FILE_SOURCES[@]}"
+       do
+               echo "${ADD_FILE_SOURCES[$i]}"
+               cp -a "${ADD_FILE_SOURCES[$i]}" "$MOUNT_DIR/${ADD_FILE_TARGETS[$i]}"
+       done
+fi
+
+if ! test -z "$ADD_FOLDER_SOURCES"; then
+       echo "Copying custom folders..."
+       for i in "${!ADD_FOLDER_SOURCES[@]}"
+       do
+               echo "${ADD_FOLDER_SOURCES[$i]}"
+               cp -a "${ADD_FOLDER_SOURCES[$i]}" "$MOUNT_DIR/${ADD_FOLDER_TARGETS[$i]}"
+       done
+fi
+
+# run applescript
+APPLESCRIPT=$(mktemp -t createdmg.tmp.XXXXXXXXXX)
+
+function applescript_source() {
+       if [ $BREW_INSTALL -eq 0 ]; then
+               cat "$AUX_PATH/template.applescript"
+       else
+               cat << 'EOS'
+               # BREW_INLINE_APPLESCRIPT_PLACEHOLDER
+EOS
+       fi
+}
+
+if [ $SKIP_JENKINS -eq 0 ]; then
+       applescript_source | sed -e "s/WINX/$WINX/g" -e "s/WINY/$WINY/g" -e "s/WINW/$WINW/g" -e 
"s/WINH/$WINH/g" -e "s/BACKGROUND_CLAUSE/$BACKGROUND_CLAUSE/g" -e 
"s/REPOSITION_HIDDEN_FILES_CLAUSE/$REPOSITION_HIDDEN_FILES_CLAUSE/g" -e "s/ICON_SIZE/$ICON_SIZE/g" -e 
"s/TEXT_SIZE/$TEXT_SIZE/g" | perl -pe  "s/POSITION_CLAUSE/$POSITION_CLAUSE/g" | perl -pe 
"s/QL_CLAUSE/$QL_CLAUSE/g" | perl -pe "s/APPLICATION_CLAUSE/$APPLICATION_CLAUSE/g" | perl -pe 
"s/HIDING_CLAUSE/$HIDING_CLAUSE/" >"$APPLESCRIPT"
+       sleep 2 # pause to workaround occasional "Can’t get disk" (-1728) issues  
+       echo "Running Applescript: /usr/bin/osascript \"${APPLESCRIPT}\" \"${VOLUME_NAME}\""
+       (/usr/bin/osascript "${APPLESCRIPT}" "${VOLUME_NAME}" || if [[ "$?" -ne 0 ]]; then echo "Failed 
running AppleScript"; hdiutil detach "${DEV_NAME}"; exit 64; fi)
+       echo "Done running the applescript..."
+       sleep 4
+       rm "$APPLESCRIPT"
+fi
+
+# make sure it's not world writeable
+echo "Fixing permissions..."
+chmod -Rf go-w "${MOUNT_DIR}" &> /dev/null || true
+echo "Done fixing permissions."
+
+# make the top window open itself on mount:
+if [ $SANDBOX_SAFE -eq 0 ]; then
+       echo "Blessing started"
+       bless --folder "${MOUNT_DIR}" --openfolder "${MOUNT_DIR}"
+       echo "Blessing finished"
+else
+       echo "Skipping blessing on sandbox"
+fi
+
+if ! test -z "$VOLUME_ICON_FILE"; then
+       # tell the volume that it has a special file attribute
+       SetFile -a C "$MOUNT_DIR"
+fi
+
+# unmount
+echo "Unmounting disk image..."
+hdiutil detach "${DEV_NAME}"
+
+# compress image
+echo "Compressing disk image..."
+hdiutil convert ${HDIUTIL_VERBOSITY} "${DMG_TEMP_NAME}" -format ${FORMAT} ${IMAGEKEY} -o 
"${DMG_DIR}/${DMG_NAME}"
+rm -f "${DMG_TEMP_NAME}"
+
+# adding EULA resources
+if [ ! -z "${EULA_RSRC}" -a "${EULA_RSRC}" != "-null-" ]; then
+       echo "adding EULA resources"
+
+       REZ_ARG=""
+       if [ ! -z "${REZ_PATH}" -a "${REZ_PATH}" != "-null-" ]; then
+               REZ_ARG="--rez ${REZ_PATH}"
+       fi
+       if [ $BREW_INSTALL -eq 0 ]; then
+               "${AUX_PATH}/dmg-license.py" "${DMG_DIR}/${DMG_NAME}" "${EULA_RSRC}" ${REZ_ARG}
+       else
+               python - "${DMG_DIR}/${DMG_NAME}" "${EULA_RSRC}" ${REZ_ARG} <<-'EOS'
+               # BREW_INLINE_LICENSE_PLACEHOLDER
+EOS
+       fi
+fi
+
+if [ ! -z "${NOINTERNET}" -a "${NOINTERNET}" == 1 ]; then
+       echo "not setting 'internet-enable' on the dmg"
+else
+       # check if hdiutil supports internet-enable
+       # support was removed in macOS 10.15
+       # https://github.com/andreyvit/create-dmg/issues/76
+       if hdiutil internet-enable -help >/dev/null 2>/dev/null 
+       then
+               hdiutil internet-enable -yes "${DMG_DIR}/${DMG_NAME}"
+       else
+               echo "hdiutil does not support internet-enable. Note it was removed in macOS 10.15."
+       fi
+fi
+
+echo "Disk image done"
+exit 0
diff --git a/package/create-dmg/sample b/package/create-dmg/sample
new file mode 100755
index 0000000..9b2e949
--- /dev/null
+++ b/package/create-dmg/sample
@@ -0,0 +1,18 @@
+#!/bin/bash
+
+# Since create-dmg does not override, be sure to delete previous DMG
+test -f Application-Installer.dmg && rm Application-Installer.dmg
+
+# Create the DMG
+./create-dmg \
+--volname "Application Installer" \
+--volicon "application\_icon.icns" \
+--background "installer\_background.png" \
+--window-pos 200 120 \
+--window-size 800 400 \
+--icon-size 100 \
+--icon "Application.app" 200 190 \
+--hide-extension "Application.app" \
+--app-drop-link 600 185 \
+"Application-Installer.dmg" \
+"source_folder/"
\ No newline at end of file
diff --git a/package/create-dmg/support/brew-me.sh b/package/create-dmg/support/brew-me.sh
new file mode 100755
index 0000000..dfc2471
--- /dev/null
+++ b/package/create-dmg/support/brew-me.sh
@@ -0,0 +1,21 @@
+#!/bin/bash
+
+# Bundle support scripts to main script
+
+cd "${0%/*}"
+
+script='../create-dmg'
+script_brew='../create-dmg-brew'
+applescript='template.applescript'
+licensescript='dmg-license.py'
+
+asl=$(awk "/BREW_INLINE_APPLESCRIPT_PLACEHOLDER/{ print NR; exit }" "$script")
+sed -n 1,$(( asl - 1 ))p "$script" | sed -e 's/BREW_INSTALL=0/BREW_INSTALL=1/g' > "$script_brew"
+cat "$applescript" >> "$script_brew"
+lsl=$(awk "/BREW_INLINE_LICENSE_PLACEHOLDER/{ print NR; exit }" "$script")
+sed -n $(( asl + 1 )),$(( lsl - 1 ))p "$script" >> "$script_brew"
+cat "$licensescript" | sed '1d' >> "$script_brew"
+sed -n $(( lsl + 1 )),\$p "$script" >> "$script_brew"
+
+mv "$script_brew" "$script"
+chmod +x "$script"
diff --git a/package/create-dmg/support/dmg-license.py b/package/create-dmg/support/dmg-license.py
new file mode 100755
index 0000000..edf04ee
--- /dev/null
+++ b/package/create-dmg/support/dmg-license.py
@@ -0,0 +1,163 @@
+#!/usr/bin/env python
+"""
+This script adds a license file to a DMG. Requires Xcode and a plain ascii text
+license file.
+Obviously only runs on a Mac.
+
+Copyright (C) 2011-2013 Jared Hobbs
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+"""
+from __future__ import print_function
+import os
+import sys
+import tempfile
+import optparse
+
+
+class Path(str):
+    def __enter__(self):
+        return self
+
+    def __exit__(self, type, value, traceback):
+        os.unlink(self)
+
+
+def mktemp(dir=None, suffix=''):
+    (fd, filename) = tempfile.mkstemp(dir=dir, suffix=suffix)
+    os.close(fd)
+    return Path(filename)
+
+
+def main(options, args):
+    dmgFile, license = args
+    with mktemp('.') as tmpFile:
+        with open(tmpFile, 'w') as f:
+            f.write("""data 'TMPL' (128, "LPic") {
+        $"1344 6566 6175 6C74 204C 616E 6775 6167"
+        $"6520 4944 4457 5244 0543 6F75 6E74 4F43"
+        $"4E54 042A 2A2A 2A4C 5354 430B 7379 7320"
+        $"6C61 6E67 2049 4444 5752 441E 6C6F 6361"
+        $"6C20 7265 7320 4944 2028 6F66 6673 6574"
+        $"2066 726F 6D20 3530 3030 4457 5244 1032"
+        $"2D62 7974 6520 6C61 6E67 7561 6765 3F44"
+        $"5752 4404 2A2A 2A2A 4C53 5445"
+};
+
+data 'LPic' (5000) {
+        $"0000 0002 0000 0000 0000 0000 0004 0000"
+};
+
+data 'STR#' (5000, "English buttons") {
+        $"0006 0D45 6E67 6C69 7368 2074 6573 7431"
+        $"0541 6772 6565 0844 6973 6167 7265 6505"
+        $"5072 696E 7407 5361 7665 2E2E 2E7A 4966"
+        $"2079 6F75 2061 6772 6565 2077 6974 6820"
+        $"7468 6520 7465 726D 7320 6F66 2074 6869"
+        $"7320 6C69 6365 6E73 652C 2063 6C69 636B"
+        $"2022 4167 7265 6522 2074 6F20 6163 6365"
+        $"7373 2074 6865 2073 6F66 7477 6172 652E"
+        $"2020 4966 2079 6F75 2064 6F20 6E6F 7420"
+        $"6167 7265 652C 2070 7265 7373 2022 4469"
+        $"7361 6772 6565 2E22"
+};
+
+data 'STR#' (5002, "English") {
+        $"0006 0745 6E67 6C69 7368 0541 6772 6565"
+        $"0844 6973 6167 7265 6505 5072 696E 7407"
+        $"5361 7665 2E2E 2E7B 4966 2079 6F75 2061"
+        $"6772 6565 2077 6974 6820 7468 6520 7465"
+        $"726D 7320 6F66 2074 6869 7320 6C69 6365"
+        $"6E73 652C 2070 7265 7373 2022 4167 7265"
+        $"6522 2074 6F20 696E 7374 616C 6C20 7468"
+        $"6520 736F 6674 7761 7265 2E20 2049 6620"
+        $"796F 7520 646F 206E 6F74 2061 6772 6565"
+        $"2C20 7072 6573 7320 2244 6973 6167 7265"
+        $"6522 2E"
+};\n\n""")
+            with open(license, 'r') as l:
+                kind = 'RTF ' if license.lower().endswith('.rtf') else 'TEXT'
+                f.write('data \'%s\' (5000, "English") {\n' % kind)
+                def escape(s):
+                    return s.strip().replace('\\', '\\\\').replace('"', '\\"').replace('\0', '')
+
+                for line in l:
+                    line = escape(line)
+                    for liner in [line[i:i+1000] for i in range(0, len(line), 1000)]:
+                        f.write('    "' + liner + '"\n')
+                    f.write('    "' + '\\n"\n')
+                f.write('};\n\n')
+            f.write("""data 'styl' (5000, "English") {
+        $"0003 0000 0000 000C 0009 0014 0000 0000"
+        $"0000 0000 0000 0000 0027 000C 0009 0014"
+        $"0100 0000 0000 0000 0000 0000 002A 000C"
+        $"0009 0014 0000 0000 0000 0000 0000"
+};\n""")
+        os.system('hdiutil unflatten -quiet "%s"' % dmgFile)
+        ret = os.system('%s -a %s -o "%s"' %
+                        (options.rez, tmpFile, dmgFile))
+        os.system('hdiutil flatten -quiet "%s"' % dmgFile)
+        if options.compression is not None:
+            os.system('cp %s %s.temp.dmg' % (dmgFile, dmgFile))
+            os.remove(dmgFile)
+            if options.compression == "bz2":
+                os.system('hdiutil convert %s.temp.dmg -format UDBZ -o %s' %
+                          (dmgFile, dmgFile))
+            elif options.compression == "gz":
+                os.system('hdiutil convert %s.temp.dmg -format ' % dmgFile +
+                          'UDZO -imagekey zlib-devel=9 -o %s' % dmgFile)
+            os.remove('%s.temp.dmg' % dmgFile)
+    if ret == 0:
+        print("Successfully added license to '%s'" % dmgFile)
+    else:
+        print("Failed to add license to '%s'" % dmgFile)
+
+if __name__ == '__main__':
+    parser = optparse.OptionParser()
+    parser.set_usage("""%prog <dmgFile> <licenseFile> [OPTIONS]
+  This program adds a software license agreement to a DMG file.
+  It requires Xcode and either a plain ascii text <licenseFile>
+  or a <licenseFile.rtf> with the RTF contents.
+
+  See --help for more details.""")
+    parser.add_option(
+        '--rez',
+        '-r',
+        action='store',
+        default='/Applications/Xcode.app/Contents/Developer/Tools/Rez',
+        help='The path to the Rez tool. Defaults to %default'
+    )
+    parser.add_option(
+        '--compression',
+        '-c',
+        action='store',
+        choices=['bz2', 'gz'],
+        default=None,
+        help='Optionally compress dmg using specified compression type. '
+             'Choices are bz2 and gz.'
+    )
+    options, args = parser.parse_args()
+    cond = len(args) != 2
+    if not os.path.exists(options.rez):
+        print('Failed to find Rez at "%s"!\n' % options.rez)
+        cond = True
+    if cond:
+        parser.print_usage()
+        sys.exit(1)
+    main(options, args)
diff --git a/package/create-dmg/support/template.applescript b/package/create-dmg/support/template.applescript
new file mode 100644
index 0000000..fee634d
--- /dev/null
+++ b/package/create-dmg/support/template.applescript
@@ -0,0 +1,74 @@
+on run (volumeName)
+       tell application "Finder"
+               tell disk (volumeName as string)
+                       open
+
+                       set theXOrigin to WINX
+                       set theYOrigin to WINY
+                       set theWidth to WINW
+                       set theHeight to WINH
+
+                       set theBottomRightX to (theXOrigin + theWidth)
+                       set theBottomRightY to (theYOrigin + theHeight)
+                       set dsStore to "\"" & "/Volumes/" & volumeName & "/" & ".DS_STORE\""
+
+                       tell container window
+                               set current view to icon view
+                               set toolbar visible to false
+                               set statusbar visible to false
+                               set the bounds to {theXOrigin, theYOrigin, theBottomRightX, theBottomRightY}
+                               set statusbar visible to false
+                               REPOSITION_HIDDEN_FILES_CLAUSE
+                       end tell
+
+                       set opts to the icon view options of container window
+                       tell opts
+                               set icon size to ICON_SIZE
+                               set text size to TEXT_SIZE
+                               set arrangement to not arranged
+                       end tell
+                       BACKGROUND_CLAUSE
+
+                       -- Positioning
+                       POSITION_CLAUSE
+
+                       -- Hiding
+                       HIDING_CLAUSE
+
+                       -- Application and QL Link Clauses
+                       APPLICATION_CLAUSE
+                       QL_CLAUSE
+                       close
+                       open
+                       -- Force saving of the size
+                       delay 1
+
+                       tell container window
+                               set statusbar visible to false
+                               set the bounds to {theXOrigin, theYOrigin, theBottomRightX - 10, 
theBottomRightY - 10}
+                       end tell
+               end tell
+
+               delay 1
+
+               tell disk (volumeName as string)
+                       tell container window
+                               set statusbar visible to false
+                               set the bounds to {theXOrigin, theYOrigin, theBottomRightX, theBottomRightY}
+                       end tell
+               end tell
+
+               --give the finder some time to write the .DS_Store file
+               delay 3
+
+               set waitTime to 0
+               set ejectMe to false
+               repeat while ejectMe is false
+                       delay 1
+                       set waitTime to waitTime + 1
+                       
+                       if (do shell script "[ -f " & dsStore & " ]; echo $?") = "0" then set ejectMe to true
+               end repeat
+               log "waited " & waitTime & " seconds for .DS_STORE to be created."
+       end tell
+end run
diff --git a/package/gimp-dmg.png b/package/gimp-dmg.png
new file mode 100644
index 0000000..049d887
Binary files /dev/null and b/package/gimp-dmg.png differ
diff --git a/package/test.sh b/package/test.sh
new file mode 100755
index 0000000..e69cbe6
--- /dev/null
+++ b/package/test.sh
@@ -0,0 +1,18 @@
+#!/bin/sh
+cd create-dmg
+
+./create-dmg \
+--volname "GIMP 2.10 Installer" \
+--volicon "/Applications/GIMP-2.10.app/Contents/Resources/gimp.icns" \
+--background "../gimp-dmg.png" \
+--window-pos 1 1 \
+--icon "GIMP-2.10.app" 190 360 \
+--window-size 640 480 \
+--icon-size 110 \
+--icon "Applications" 110 110 \
+--hide-extension "Applications" \
+--app-drop-link 450 360 \
+--format UDBZ \
+"../test.dmg" \
+"/Applications/GIMP-2.10.app"
+cd ..
\ No newline at end of file


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]