Thank you very much for supporting me. How about this? ===Patch Start === --- ./archlinux-java.orig 2021-09-30 19:21:57.758914707 +0900 +++ ./archlinux-java 2021-09-30 19:22:19.588869274 +0900 @@ -8,14 +8,15 @@ 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 +25,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,8 +35,8 @@ 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 @@ -44,34 +45,34 @@ get_installed_javas() { 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 + test "x$1" != "x${DEFAULT_NAME}" && test -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 +84,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 +113,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 +137,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 +152,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) <COMMAND>" + echo "$(basename "${0}") <COMMAND>" 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 +176,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 ===Patch Finish === 2021年9月30日(木) 17:24 Matej Dujava <mdujava+aur@xxxxxxxxxxxx>: > On Thu, Sep 30, 2021 at 02:05:41PM +0900, 山田ハヤオ via arch-general wrote: > >The archlinux-java script in the java-common package has a lot of code > that > >is inappropriate as a Bash script. (ShellCheck prints a lot of errors.) > >I have created a patch that fixes these errors with minimal changes. > >I put the patch on GitHub Gists because it collapses for some reason when > I > >send the patch by email. > >all.patch is a patch that contains all the changes, and the other files > >split the changes by function. > >This is my first time sending a patch to a mailing list, so there may be > >something wrong with the way it is sent. > > > >Patch > >https://gist.github.com/Hayao0819/bacccc3eebeab73159001f60c9d35a43 > > Hey, > if you have problems sending patch in email you can take a look at [1]. > It might be a problem of the email client converting Tabs to spaces or > removing whitespaces at the start or end of line. You might use > git-send-patch. > > Usualy unified patch is send `patch -U` instead of the default. > > [1] > https://www.kernel.org/doc/html/latest/process/submitting-patches.html#no-mime-no-links-no-compression-no-attachments-just-plain-text >