# HG changeset patch # User David Barts # Date 1588399564 25200 # Node ID 89d7f4d91f6787ec74ef6dde3fe030a39a18303a # Parent d794ef80f9b009f5716702aed4b92740ac947d6d Got a working, non-bloated Apple Mac bundle! diff -r d794ef80f9b0 -r 89d7f4d91f67 Building.html --- a/Building.html Fri May 01 11:52:46 2020 -0700 +++ b/Building.html Fri May 01 23:06:04 2020 -0700 @@ -29,6 +29,7 @@
  • Exiv2
  • A C++ Compiler
  • Make (Nmake on Windows)
  • +
  • Osdep
  • JpegWasher Is Not Pure Java

    This means two things:

    diff -r d794ef80f9b0 -r 89d7f4d91f67 Makefile.mac --- a/Makefile.mac Fri May 01 11:52:46 2020 -0700 +++ b/Makefile.mac Fri May 01 23:06:04 2020 -0700 @@ -6,7 +6,10 @@ .PHONY: all checkenv -all: checkenv $(BDIR)/libjni.dylib $(BDIR)/libexiv2.dylib +all: mkdirs checkenv $(BDIR)/libjni.dylib $(BDIR)/libexiv2.dylib + +mkdirs: + @[ -d "$(BDIR)" ] || mkdir -p "$(BDIR)" checkenv: @if [ -z "$(JRE_HOME)" -o -z "$(EXIV2_HOME)" ]; then \ diff -r d794ef80f9b0 -r 89d7f4d91f67 build.xml --- a/build.xml Fri May 01 11:52:46 2020 -0700 +++ b/build.xml Fri May 01 23:06:04 2020 -0700 @@ -1,7 +1,6 @@ @@ -58,7 +57,8 @@ - + + @@ -68,8 +68,10 @@ + + @@ -77,18 +79,6 @@ - - - - - - - - - @@ -151,7 +141,7 @@ - + @@ -159,7 +149,7 @@ - + @@ -175,7 +165,7 @@ description="Compile Java sources to ${work.home}"> - + @@ -196,7 +186,73 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -204,6 +260,11 @@ + + + + + - + diff -r d794ef80f9b0 -r 89d7f4d91f67 package-files/osx/DS_Store Binary file package-files/osx/DS_Store has changed diff -r d794ef80f9b0 -r 89d7f4d91f67 package-files/osx/Info.plist --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/package-files/osx/Info.plist Fri May 01 23:06:04 2020 -0700 @@ -0,0 +1,47 @@ + + + + + + CFBundleDevelopmentRegion + English + CFBundleDisplayName + @app.name@ + CFBundleExecutable + JavaApplicationStub + CFBundleIconFile + @app.name@.icns + CFBundleIdentifier + @app.domain@ + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + @app.name@ + CFBundlePackageType + APPL + CFBundleShortVersionString + @app.version@ + CFBundleVersion + @app.version@ + NSHumanReadableCopyright + Copyright © 2020, David Barts + + CFBundleAllowMixedLocalizations + false + LSApplicationCategoryType + public.app-category.photography + + JVMMainClassName + @app.entry@ + JVMClassPath + Contents/Java/@lc.app.name@.jar + JVMVersion + @jvm.version@+ + JVMOptions + + -Dapple.awt.textantialiasing=true + -Dapple.laf.useScreenMenuBar=true + -Dapple.awt.antialiasing=true + + + diff -r d794ef80f9b0 -r 89d7f4d91f67 package-files/osx/JavaApplicationStub --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/package-files/osx/JavaApplicationStub Fri May 01 23:06:04 2020 -0700 @@ -0,0 +1,166 @@ +#!/bin/bash + +# This is based on Tobias Fischer's universalJavaApplicationStub: +# https://github.com/tofi86/universalJavaApplicationStub +# +# Therefore this part of JpegWasher is covered by the same MIT license +# that his code is: +# +# The MIT License (MIT) +# +# Copyright (c) 2014-2020 Tobias Fischer +# +# 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. + +# Establish our application names +appname="@app.name@" +appdom="@app.domain@" + +# Make a place for our logs to go +appsupp="$HOME/Library/Application Support/$appdom" +logfile="$appsupp/launcher.log" + +function die { + osascript -e "tell application \"System Events\" to display dialog \"${1}\" with title \"Fatal Error\" buttons {\" OK \"} default button 1" + exit ${2:-1} +} + +# Initialize files and dirs, bail if we can't. +if [ ! -d "$appsupp" ] +then + if ! mkdir -p "$appsupp" + then + die "Unable to create folder '$appsupp'" 2 + fi +fi +> "$logfile" +if [ $? -ne 0 ] +then + die "Unable to create file '$logfile'" 2 +fi + +function stub_logger { + echo "$(date +%c) - $1" >> "$logfile" +} + +# Was originally just for debugging, but I think this could be useful +# for later troubleshooting "in the wild." +stub_logger "execution begins" +{ + echo "****** BEGIN ARGUMENT AND ENVIRONMENT DUMP *******" + echo "Arguments:" "$0" "$@" + echo "Directory:" $(pwd) + env + echo "******* END ARGUMENT AND ENVIRONMENT DUMP ********" +} >> "$logfile" + +# Change to the application root directory, two up from where this script +# (which should contain an absolute path) is. +mydir="${0%/*}" +cd "$mydir/../.." || die "Unable to cd '$mydir/../..'" + +# Determine where Java is, bail if we can't. +if [ -n "$JAVA_HOME" ] +then + if [ ! -d "$JAVA_HOME" ] + then + die "'$JAVA_HOME' does not exist" + fi +else + export JAVA_HOME="$(/usr/libexec/java_home)" + if [ $? -ne 0 -o ! -d "$JAVA_HOME" ] + then + die "Unable to locate Java." + fi +fi + +java="$JAVA_HOME/bin/java" +if [ ! -x "$java" ] +then + die "'$java' not found or not executable" +fi + +# function 'plist_get()' +# +# read a specific Plist key with 'PlistBuddy' utility +# +# @param1 the Plist key with leading colon ':' +# @return the value as String or Array +################################################################################ +function plist_get { + /usr/libexec/PlistBuddy -c "print $1" Contents/Info.plist 2> /dev/null +} +function must_get { + plist_get "$@" || die "Info.plist key '$1' not found." +} + +# Load some parameters from Contents/Info.plist +estat=0 +CFBundleName=$(must_get ':CFBundleName') +CFBundleIconFile=$(must_get ':CFBundleIconFile') +JVMMainClassName=$(must_get ':JVMMainClassName') +JVMClassPath=$(must_get ':JVMClassPath') +JVMVersion=$(must_get ':JVMVersion') + +# Sanity check our JVM version +if [[ "$JVMVersion" == *+ ]] +then + op='>' + JVMVersion="${JVMVersion%+}" +else + op='=' +fi +version=$("$java" -version 2>&1 | awk '/version/{print $3}' | sed -E -e 's/"//g' -e 's/-ea//g') +if [ ! "$version" "$op" "$JVMVersion" ] +then + die "'$java' too old" +fi + +# Load the JVMOptions array (if found) +JVMOptions=() +let i=0 +while true +do + j="$(plist_get :JVMOptions:$i)" + if [ -z "$j" ] + then + break + fi + JVMOptions+=("$j") + let i+=1 +done + +# Fatal error if we cannot change to HOME or HOME not defined +approot="$(pwd)" +if [ -z "$HOME" ] +then + die "HOME not defined!" +fi +cd "$HOME" || die "Unable to cd '$HOME'" + +# And off we go! +jcmd=( "$JAVA_HOME/bin/java" -cp "$approot/$JVMClassPath" + -Xdock:icon="$approot/Contents/Resources/$CFBundleIconFile" + -Xdock:name="$CFBundleName" "${JVMOptions[@]}" "$JVMMainClassName" ) + +stub_logger "Executing: ${jcmd[@]}" +exec "${jcmd[@]}" + +# This shouldn't happen... +die "Could not launch Java." diff -r d794ef80f9b0 -r 89d7f4d91f67 package-files/osx/jedit Binary file package-files/osx/jedit has changed