--- ./archlinux-java.orig 2021-09-30 19:21:57.758914707 +0900 +++ ./archlinux-java 2021-09-30 23:51:50.592804607 +0900 @@ -4,18 +4,20 @@ # This program may be freely redistributed under the terms of the GNU General Public License # # Author: Guillaume ALAUX +# Yamada Hayao JVM_DIR=/usr/lib/jvm DEFAULT_NAME=default DEFAULT_PATH=${JVM_DIR}/${DEFAULT_NAME} -DEFAULT_NAME_JRE=default-runtime +DEFAULT_NAME_JRE="default-runtime" DEFAULT_PATH_JRE=${JVM_DIR}/${DEFAULT_NAME_JRE} # Utility functions check_root() { - if [ $(id -u) -ne 0 ]; then + #if [ $(id -u) -ne 0 ]; then + if (( UID != 0 )); then echo 'This script must be run as root' exit 1 fi @@ -24,7 +26,7 @@ # $1: parameter count given to this script for this option # $2: expected parameter count for this option check_param_count() { - if [ $1 -ne $2 ]; then + if [[ "${1}" -ne "${2}" ]]; then echo 'Wrong parameter count' exit 2 fi @@ -34,44 +36,44 @@ get_default_java() { path=$(readlink -e ${DEFAULT_PATH}) - if [ "x${path}" != "x/dev/null" ]; then - echo ${path/${JVM_DIR}\/} + if [[ "${path}" != "/dev/null" ]]; then + echo "${path/${JVM_DIR}\/}" else echo "" fi } get_installed_javas() { - if [ -d ${JVM_DIR} ]; then + if [[ -d "${JVM_DIR}" ]]; then for dir in $(find ${JVM_DIR} -mindepth 1 -maxdepth 1 -type d | sort); do - if [ -x ${dir}/bin/java ]; then - javas+=(${dir/${JVM_DIR}\/}) + if [ -x "${dir}/bin/java" ]; then + javas+=("${dir/${JVM_DIR}\/}") else - if [ -x ${dir}/jre/bin/java ]; then - javas+=(${dir/${JVM_DIR}\/}/jre) + if [ -x "${dir}/jre/bin/java" ]; then + javas+=("${dir/${JVM_DIR}\/}/jre") fi fi done fi - echo ${javas[@]} + echo "${javas[*]}" } # $1: Java environment name to test is_java_valid() { - test "x$1" != "x${DEFAULT_NAME}" && test -x ${JVM_DIR}/$1/bin/java + [[ "${1}" != "${DEFAULT_NAME}" ]] && [[ -x "${JVM_DIR}/${1}/bin/java" ]] } # $1: Java environment name to set as default set_default_link_to() { - new_default=$1 - unlink ${DEFAULT_PATH} 2>/dev/null - ln -sf ${new_default} ${DEFAULT_PATH} - - unlink ${DEFAULT_PATH_JRE} 2>/dev/null - if [[ -d ${new_default}/jre ]]; then - ln -sf ${new_default}/jre ${DEFAULT_PATH_JRE} + new_default="${1}" + unlink "${DEFAULT_PATH}" 2>/dev/null + ln -sf "${new_default}" "${DEFAULT_PATH}" + + unlink "${DEFAULT_PATH_JRE}" 2>/dev/null + if [[ -d "${new_default}/jre" ]]; then + ln -sf "${new_default}/jre" "${DEFAULT_PATH_JRE}" else - ln -sf ${new_default} ${DEFAULT_PATH_JRE} + ln -sf "${new_default}" "${DEFAULT_PATH_JRE}" fi } @@ -83,23 +85,24 @@ # First level functions do_status() { - installed_java=($(get_installed_javas)) + #installed_java=($(get_installed_javas)) + IFS=" " read -r -a installed_java < <(get_installed_javas) if [ ${#installed_java[@]} -eq 0 ]; then echo 'No compatible Java environment installed' else default_java=$(get_default_java) echo 'Available Java environments:' - for java in ${installed_java[@]}; do + for java in "${installed_java[@]}"; do # We discoverd this Java env but its JRE is actually set as default if [ "${java}/jre" = "${default_java}" ]; then echo -e " ${java} (${java}/jre default)" - elif [ ${java} = "${default_java}" ]; then + elif [ "${java}" = "${default_java}" ]; then echo -e " ${java} (default)" else echo " ${java}" fi done - if [ -z ${default_java} ]; then + if [ -z "${default_java}" ]; then echo "No Java environment set as default" fi fi @@ -111,14 +114,14 @@ # $1: Java environment name to set as default do_set() { - if ! is_java_valid $1; then + if ! is_java_valid "${1}"; then echo "'${JVM_DIR}/$1' is not a valid Java environment path" exit 1 fi default=$(get_default_java) - if [ "x$1" != "x${default}" ] || ! is_java_valid ${default}; then + if [[ "$1" != "${default}" ]] || ! is_java_valid "${default}"; then unset_default_link - set_default_link_to $1 + set_default_link_to "${1}" fi #parent_dir=$(dirname $1) @@ -135,11 +138,11 @@ do_fix() { default=$(get_default_java) - if is_java_valid ${default}; then + if is_java_valid "${default}"; then # If its parent is also a valid Java environment - if is_java_valid $(dirname ${default}); then + if is_java_valid "$(dirname "${default}")"; then unset_default_link - set_default_link_to $(dirname ${default}) + set_default_link_to "$(dirname "${default}")" fi else prev=$(readlink ${DEFAULT_PATH}) @@ -150,20 +153,21 @@ # - first potential fixes of user choices, # - then OpenJDK8 as it is considered a default in Arch Linux # - finally, any installed environment - to_check=(${potential_fixes[@]} ${openjdk8[@]} $(get_installed_javas)) - for java in ${to_check[@]}; do - if ! is_java_valid $(get_default_java) && is_java_valid ${java}; then - set_default_link_to ${java} + IFS=" " read -r -a to_check < <(get_installed_javas) + to_check=("${potential_fixes[@]}" "${openjdk8[@]}" "${to_check[@]}") + for java in "${to_check[@]}"; do + if ! is_java_valid "$(get_default_java)" && is_java_valid "${java}"; then + set_default_link_to "${java}" fi done fi - if ! is_java_valid $(get_default_java); then + if ! is_java_valid "$(get_default_java)"; then echo 'No valid Java environment found' fi } usage() { - echo "$(basename $0) " + echo "$(basename "${0}") " echo -e "\nCOMMAND:" echo -e '\tstatus\t\tList installed Java environments and enabled one' echo -e '\tget\t\tReturn the short name of the Java environment set as default' @@ -173,12 +177,12 @@ } ## Main -case $1 in +case "${1}" in 'status') do_status;; 'get') do_get;; - 'set') check_root; check_param_count $# 2; do_set $2;; + 'set') check_root; check_param_count "${#}" 2; do_set "${2}";; 'unset') check_root; do_unset;; 'fix') check_root; do_fix;; 'help' | '--help' | '-h' | '') usage;; - *) echo "$(basename $0): unknown option '$@'"; exit 1;; + *) echo "$(basename "${0}"): unknown option '${*}'"; exit 1;; esac