Ticket #22193: josm-launcher.patch
| File josm-launcher.patch, 12.3 KB (added by , 4 years ago) |
|---|
-
native/linux/tested/usr/bin/josm
Description: Improve josm launchers. * Use `/bin/bash` instead of `/usr/bin/env bash` usrmerge systems have both `/bin/bash` and `/usr/bin/bash`, non-usrmerge systems only have `/bin/bash`. * Set `ALTERNATIVE_JDK` only if `/etc/alternatives/java` exists. While not only Debian based distributions use the alternatives system, not all distributions do. * Use 4 spaces for indentation consistently. Some indentation used tabs, others 2 spaces. * Simplify `java_version` function. Piping to `cat` is useless. * Don't use `command -v` to test whether `dpkg` is available. The command may be an alias which results in output like: ``` dpkg is aliased to `donalds-porn-kink-game' ``` * Fix issues reported by `shellcheck`. SC2086 is disabled for `$JAVA_OPTS` because that only works unquoted. Author: Bas Couwenberg <sebastic@debian.org> Bug: https://josm.openstreetmap.de/ticket/22193
a b 1 #!/ usr/bin/envbash1 #!/bin/bash 2 2 # Simple wrapper script used to start JOSM in Debian 3 3 set -e 4 4 5 5 # First, the alternative (if known to work) or users preference as defined by $JAVA_HOME. Next, use OpenJDK. 6 6 # Override to a specific one using $JAVACMD 7 ALTERNATIVE_JDK=$(readlink -n -f /etc/alternatives/java || true) 7 if [ -e "/etc/alternatives/java" ]; then 8 ALTERNATIVE_JDK=$(readlink -n -f /etc/alternatives/java) 9 fi 8 10 9 11 if [ -v JAVA_HOME ]; then 10 12 JAVA_CMDS="$JAVA_HOME/bin/java" … … else 13 15 fi 14 16 15 17 dpkg_java() { 16 # Let's get the current architecture -- needed for multiarchified Java17 ARCH=$(dpkg --print-architecture 2> /dev/null || true)18 # If OpenJDK is only available headless, do not try it19 if dpkg --get-selections "openjdk-*-jre" | grep install$ > /dev/null \20 || dpkg --get-selections "openjdk-*-jre:$ARCH" | grep install$ > /dev/null ; then21 # LTS versions in decreased order22 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-17-openjdk/bin/java /usr/lib/jvm/java-17-openjdk-$ARCH/bin/java"23 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-11-openjdk/bin/java /usr/lib/jvm/java-11-openjdk-$ARCH/bin/java"24 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-8-openjdk/bin/java /usr/lib/jvm/java-8-openjdk-$ARCH/bin/java"25 # Released versions in decreased order26 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-18-openjdk/bin/java /usr/lib/jvm/java-18-openjdk-$ARCH/bin/java"27 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-16-openjdk/bin/java /usr/lib/jvm/java-16-openjdk-$ARCH/bin/java"28 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-15-openjdk/bin/java /usr/lib/jvm/java-15-openjdk-$ARCH/bin/java"29 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-14-openjdk/bin/java /usr/lib/jvm/java-14-openjdk-$ARCH/bin/java"30 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-13-openjdk/bin/java /usr/lib/jvm/java-13-openjdk-$ARCH/bin/java"31 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-12-openjdk/bin/java /usr/lib/jvm/java-12-openjdk-$ARCH/bin/java"32 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-10-openjdk/bin/java /usr/lib/jvm/java-10-openjdk-$ARCH/bin/java"33 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-9-openjdk/bin/java /usr/lib/jvm/java-9-openjdk-$ARCH/bin/java"34 # Development version(s)35 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-19-openjdk/bin/java /usr/lib/jvm/java-19-openjdk-$ARCH/bin/java"36 fi18 # Let's get the current architecture -- needed for multiarchified Java 19 ARCH=$(dpkg --print-architecture 2> /dev/null || true) 20 # If OpenJDK is only available headless, do not try it 21 if dpkg --get-selections "openjdk-*-jre" | grep install$ > /dev/null \ 22 || dpkg --get-selections "openjdk-*-jre:$ARCH" | grep install$ > /dev/null ; then 23 # LTS versions in decreased order 24 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-17-openjdk/bin/java /usr/lib/jvm/java-17-openjdk-$ARCH/bin/java" 25 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-11-openjdk/bin/java /usr/lib/jvm/java-11-openjdk-$ARCH/bin/java" 26 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-8-openjdk/bin/java /usr/lib/jvm/java-8-openjdk-$ARCH/bin/java" 27 # Released versions in decreased order 28 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-18-openjdk/bin/java /usr/lib/jvm/java-18-openjdk-$ARCH/bin/java" 29 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-16-openjdk/bin/java /usr/lib/jvm/java-16-openjdk-$ARCH/bin/java" 30 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-15-openjdk/bin/java /usr/lib/jvm/java-15-openjdk-$ARCH/bin/java" 31 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-14-openjdk/bin/java /usr/lib/jvm/java-14-openjdk-$ARCH/bin/java" 32 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-13-openjdk/bin/java /usr/lib/jvm/java-13-openjdk-$ARCH/bin/java" 33 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-12-openjdk/bin/java /usr/lib/jvm/java-12-openjdk-$ARCH/bin/java" 34 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-10-openjdk/bin/java /usr/lib/jvm/java-10-openjdk-$ARCH/bin/java" 35 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-9-openjdk/bin/java /usr/lib/jvm/java-9-openjdk-$ARCH/bin/java" 36 # Development version(s) 37 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-19-openjdk/bin/java /usr/lib/jvm/java-19-openjdk-$ARCH/bin/java" 38 fi 37 39 } 38 40 39 41 java_version() { 40 ${1} -version 2>&1 | head -n1 | awk '{print $3}' | awk -F'.' '{gsub(/"/, ""); print $1}' | cat42 ${1} -version 2>&1 | head -n1 | awk -F'"' '{print $2}' | awk -F'.' '{print $1}' 41 43 } 42 44 43 if [ -x "$(command -v dpkg)" ]; then44 dpkg_java45 if dpkg --version > /dev/null 2>&1; then 46 dpkg_java 45 47 fi 48 46 49 # Undetermined version 47 50 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/default-java/bin/java /usr/bin/java" 48 51 JOSM_VERSION="josm" 49 52 50 53 if [ -f "/etc/default/${JOSM_VERSION}" ]; then 54 # shellcheck source=/etc/default/josm 51 55 . "/etc/default/${JOSM_VERSION}" 52 56 fi 53 57 54 58 JAVA_OPTS="-Djosm.restart=true -Djava.net.useSystemProxies=true $JAVA_OPTS" 55 59 56 if [ -z "${JAVACMD}" ] ; then60 if [ -z "${JAVACMD}" ] && [ -n "${ALTERNATIVE_JDK}" ]; then 57 61 for jcmd in $JAVA_CMDS; do 58 62 if [ "z$ALTERNATIVE_JDK" = "z$(readlink -n -f "$jcmd")" ] && [ -z "${JAVACMD}" ] && [ -x "$jcmd" ]; then 59 63 JAVACMD="$jcmd" … … fi 73 77 74 78 if [ "$JAVACMD" ]; then 75 79 echo "Using $JAVACMD to execute ${JOSM_VERSION}." || true 76 JAVA_VERSION=$(java_version ${JAVACMD})80 JAVA_VERSION=$(java_version "${JAVACMD}") 77 81 JAVAFX_HOME="${JAVAFX_HOME:-/usr/share/openjfx/lib}" 78 82 JOSM_PATH="${JOSM_PATH:-/usr/share/${JOSM_VERSION}/${JOSM_VERSION}.jar}" 79 83 if [[ "${JAVA_VERSION}" -ge 11 ]]; then … … if [ "$JAVACMD" ]; then 86 90 fi 87 91 set +e 88 92 while true; do 93 # shellcheck disable=SC2086 89 94 $JAVACMD $JAVA_OPTS -jar "${JOSM_PATH}" "$@" 90 95 if [ "z$?" != "z9" ]; then 91 96 break -
native/linux/latest/usr/bin/josm-latest
a b 1 #!/ usr/bin/envbash1 #!/bin/bash 2 2 # Simple wrapper script used to start JOSM in Debian 3 3 set -e 4 4 5 5 # First, the alternative (if known to work) or users preference as defined by $JAVA_HOME. Next, use OpenJDK. 6 6 # Override to a specific one using $JAVACMD 7 ALTERNATIVE_JDK=$(readlink -n -f /etc/alternatives/java || true) 7 if [ -e "/etc/alternatives/java" ]; then 8 ALTERNATIVE_JDK=$(readlink -n -f /etc/alternatives/java) 9 fi 8 10 9 11 if [ -v JAVA_HOME ]; then 10 12 JAVA_CMDS="$JAVA_HOME/bin/java" … … else 13 15 fi 14 16 15 17 dpkg_java() { 16 # Let's get the current architecture -- needed for multiarchified Java17 ARCH=$(dpkg --print-architecture 2> /dev/null || true)18 # If OpenJDK is only available headless, do not try it19 if dpkg --get-selections "openjdk-*-jre" | grep install$ > /dev/null \20 || dpkg --get-selections "openjdk-*-jre:$ARCH" | grep install$ > /dev/null ; then21 # LTS versions in decreased order22 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-17-openjdk/bin/java /usr/lib/jvm/java-17-openjdk-$ARCH/bin/java"23 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-11-openjdk/bin/java /usr/lib/jvm/java-11-openjdk-$ARCH/bin/java"24 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-8-openjdk/bin/java /usr/lib/jvm/java-8-openjdk-$ARCH/bin/java"25 # Released versions in decreased order26 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-18-openjdk/bin/java /usr/lib/jvm/java-18-openjdk-$ARCH/bin/java"27 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-16-openjdk/bin/java /usr/lib/jvm/java-16-openjdk-$ARCH/bin/java"28 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-15-openjdk/bin/java /usr/lib/jvm/java-15-openjdk-$ARCH/bin/java"29 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-14-openjdk/bin/java /usr/lib/jvm/java-14-openjdk-$ARCH/bin/java"30 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-13-openjdk/bin/java /usr/lib/jvm/java-13-openjdk-$ARCH/bin/java"31 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-12-openjdk/bin/java /usr/lib/jvm/java-12-openjdk-$ARCH/bin/java"32 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-10-openjdk/bin/java /usr/lib/jvm/java-10-openjdk-$ARCH/bin/java"33 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-9-openjdk/bin/java /usr/lib/jvm/java-9-openjdk-$ARCH/bin/java"34 # Development version(s)35 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-19-openjdk/bin/java /usr/lib/jvm/java-19-openjdk-$ARCH/bin/java"36 fi18 # Let's get the current architecture -- needed for multiarchified Java 19 ARCH=$(dpkg --print-architecture 2> /dev/null || true) 20 # If OpenJDK is only available headless, do not try it 21 if dpkg --get-selections "openjdk-*-jre" | grep install$ > /dev/null \ 22 || dpkg --get-selections "openjdk-*-jre:$ARCH" | grep install$ > /dev/null ; then 23 # LTS versions in decreased order 24 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-17-openjdk/bin/java /usr/lib/jvm/java-17-openjdk-$ARCH/bin/java" 25 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-11-openjdk/bin/java /usr/lib/jvm/java-11-openjdk-$ARCH/bin/java" 26 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-8-openjdk/bin/java /usr/lib/jvm/java-8-openjdk-$ARCH/bin/java" 27 # Released versions in decreased order 28 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-18-openjdk/bin/java /usr/lib/jvm/java-18-openjdk-$ARCH/bin/java" 29 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-16-openjdk/bin/java /usr/lib/jvm/java-16-openjdk-$ARCH/bin/java" 30 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-15-openjdk/bin/java /usr/lib/jvm/java-15-openjdk-$ARCH/bin/java" 31 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-14-openjdk/bin/java /usr/lib/jvm/java-14-openjdk-$ARCH/bin/java" 32 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-13-openjdk/bin/java /usr/lib/jvm/java-13-openjdk-$ARCH/bin/java" 33 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-12-openjdk/bin/java /usr/lib/jvm/java-12-openjdk-$ARCH/bin/java" 34 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-10-openjdk/bin/java /usr/lib/jvm/java-10-openjdk-$ARCH/bin/java" 35 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-9-openjdk/bin/java /usr/lib/jvm/java-9-openjdk-$ARCH/bin/java" 36 # Development version(s) 37 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/java-19-openjdk/bin/java /usr/lib/jvm/java-19-openjdk-$ARCH/bin/java" 38 fi 37 39 } 38 40 39 41 java_version() { 40 ${1} -version 2>&1 | head -n1 | awk '{print $3}' | awk -F'.' '{gsub(/"/, ""); print $1}' | cat42 ${1} -version 2>&1 | head -n1 | awk -F'"' '{print $2}' | awk -F'.' '{print $1}' 41 43 } 42 44 43 if [ -x "$(command -v dpkg)" ]; then44 dpkg_java45 if dpkg --version > /dev/null 2>&1; then 46 dpkg_java 45 47 fi 48 46 49 # Undetermined version 47 50 JAVA_CMDS="${JAVA_CMDS} /usr/lib/jvm/default-java/bin/java /usr/bin/java" 48 51 JOSM_VERSION="josm-latest" 49 52 50 53 if [ -f "/etc/default/${JOSM_VERSION}" ]; then 54 # shellcheck source=/etc/default/josm-latest 51 55 . "/etc/default/${JOSM_VERSION}" 52 56 fi 53 57 54 58 JAVA_OPTS="-Djosm.restart=true -Djosm.dir.name=JOSM-latest -Djava.net.useSystemProxies=true $JAVA_OPTS" 55 59 56 if [ -z "${JAVACMD}" ] ; then60 if [ -z "${JAVACMD}" ] && [ -n "${ALTERNATIVE_JDK}" ]; then 57 61 for jcmd in $JAVA_CMDS; do 58 62 if [ "z$ALTERNATIVE_JDK" = "z$(readlink -n -f "$jcmd")" ] && [ -z "${JAVACMD}" ] && [ -x "$jcmd" ]; then 59 63 JAVACMD="$jcmd" … … fi 73 77 74 78 if [ "$JAVACMD" ]; then 75 79 echo "Using $JAVACMD to execute ${JOSM_VERSION}." || true 76 JAVA_VERSION=$(java_version ${JAVACMD})80 JAVA_VERSION=$(java_version "${JAVACMD}") 77 81 JAVAFX_HOME="${JAVAFX_HOME:-/usr/share/openjfx/lib}" 78 82 JOSM_PATH="${JOSM_PATH:-/usr/share/${JOSM_VERSION}/${JOSM_VERSION}.jar}" 79 83 if [[ "${JAVA_VERSION}" -ge 11 ]]; then … … if [ "$JAVACMD" ]; then 86 90 fi 87 91 set +e 88 92 while true; do 93 # shellcheck disable=SC2086 89 94 $JAVACMD $JAVA_OPTS -jar "${JOSM_PATH}" "$@" 90 95 if [ "z$?" != "z9" ]; then 91 96 break
