diff --git a/.jdkw b/.jdkw
index 16e417d..36e45d1 100644
--- a/.jdkw
+++ b/.jdkw
@@ -1,5 +1,4 @@
JDKW_RELEASE=latest
JDKW_DIST=zulu
-JDKW_BUILD=8.38.0.13
-JDKW_VERSION=8.0.212
-JDKW_VERBOSE=true
+JDKW_BUILD=17.36.13-ca
+JDKW_VERSION=17.0.4
diff --git a/jdk-wrapper.sh b/jdk-wrapper.sh
index aa955d8..7c7ace0 100755
--- a/jdk-wrapper.sh
+++ b/jdk-wrapper.sh
@@ -17,6 +17,12 @@
# For documentation please refer to:
# https://github.com/KoskiLabs/jdk-wrapper/blob/master/README.md
+HTTP_PROTOCOL="http"
+FILE_PROTOCOL="file"
+
+LATEST_RELEASE="latest"
+SNAPSHOT_RELEASE="snapshot"
+
log_err() {
l_prefix=$(date +'%H:%M:%S')
printf "[%s] %s\\n" "${l_prefix}" "$@" 1>&2;
@@ -42,35 +48,63 @@ safe_command() {
checksum() {
l_file="$1"
- checksum_exec=""
+ l_checksum_exec=""
+ l_checksum_args=""
if command -v sha256sum > /dev/null; then
- checksum_exec="sha256sum"
+ l_checksum_exec="sha256sum"
elif command -v shasum > /dev/null; then
- checksum_exec="shasum -a 256"
+ l_checksum_exec="shasum"
+ l_checksum_args="-a 256"
elif command -v sha1sum > /dev/null; then
- checksum_exec="sha1sum"
+ l_checksum_exec="sha1sum"
elif command -v md5 > /dev/null; then
- checksum_exec="md5"
+ l_checksum_exec="md5"
fi
- if [ -z "${checksum_exec}" ]; then
+ if [ -z "${l_checksum_exec}" ]; then
log_err "ERROR: No supported checksum command found!"
exit 1
fi
- "${checksum_exec}" < "${l_file}"
+ ${l_checksum_exec} ${l_checksum_args} < "${l_file}"
}
rand() {
awk 'BEGIN {srand();printf "%d\n", (rand() * 10^8);}'
}
-download_if_needed() {
- file="$1"
- path="$2"
- if [ ! -f "${path}/${file}" ]; then
- jdkw_url="${JDKW_BASE_URI}/releases/download/${JDKW_RELEASE}/${file}"
- log_out "Downloading ${file} from ${jdkw_url}"
- safe_command "curl ${curl_options} -f -k -L -o \"${path}/${file}\" \"${jdkw_url}\""
- safe_command "chmod +x \"${path}/${file}\""
+get_protocol() {
+ case "${JDKW_BASE_URI}" in
+ http://*|https://*)
+ printf "%s" "${HTTP_PROTOCOL}"
+ ;;
+ file://*)
+ printf "%s" "${FILE_PROTOCOL}"
+ ;;
+ *)
+ log_err "ERROR: Unsupported protocol in JDKW_BASE_URI: ${JDKW_BASE_URI}"
+ exit 1
+ esac
+}
+
+obtain_if_needed() {
+ l_file="$1"
+ l_target_path="$2"
+ if [ ! -f "${l_target_path}/${l_file}" ]; then
+ case "${JDKW_BASE_URI}" in
+ http://*|https://*)
+ l_jdkw_url="${JDKW_BASE_URI}/releases/download/${JDKW_RELEASE}/${l_file}"
+ log_out "Downloading ${l_file} from ${l_jdkw_url}"
+ safe_command "curl ${curl_options} -f -k -L -o \"${l_target_path}/${l_file}\" \"${l_jdkw_url}\""
+ ;;
+ file://*)
+ l_jdkw_path="${JDKW_BASE_URI#file://}/${l_file}"
+ log_out "Copying ${l_file} from ${l_jdkw_path}"
+ safe_command "cp \"${l_jdkw_path}\" \"${l_target_path}/${l_file}\""
+ ;;
+ *)
+ log_err "ERROR: Unsupported protocol in JDKW_BASE_URI: ${JDKW_BASE_URI}"
+ exit 1
+ esac
+ safe_command "chmod +x \"${l_target_path}/${l_file}\""
fi
}
@@ -96,7 +130,6 @@ done < "${l_fifo}"
safe_command "rm \"${l_fifo}\""
# Process (but do not load) properties from command line arguments
-command=
cmd_configuration=
for arg in "$@"; do
jdkw_arg=$(echo "${arg}" | grep '^JDKW_.*')
@@ -107,13 +140,6 @@ for arg in "$@"; do
if [ -n "${jdkw_arg}" ]; then
cmd_configuration="${cmd_configuration}${arg} "
fi
- case "${arg}" in
- *\'*)
- arg=$(printf "%s" "$arg" | sed "s/'/'\"'\"'/g")
- ;;
- *) : ;;
- esac
- command="${command} '${arg}'"
done
# Default base directory to current working directory
@@ -142,7 +168,10 @@ if [ -z "${JDKW_BASE_URI}" ]; then
JDKW_BASE_URI="https://github.com/KoskiLabs/jdk-wrapper"
fi
if [ -z "${JDKW_RELEASE}" ]; then
- JDKW_RELEASE="latest"
+ JDKW_RELEASE="${LATEST_RELEASE}"
+ if [ $(get_protocol) = "${FILE_PROTOCOL}" ]; then
+ JDKW_RELEASE="${SNAPSHOT_RELEASE}"
+ fi
log_out "Defaulted to version ${JDKW_RELEASE}"
fi
if [ -z "${JDKW_TARGET}" ]; then
@@ -154,7 +183,7 @@ if [ -z "${JDKW_VERBOSE}" ]; then
fi
# Resolve latest version
-if [ "${JDKW_RELEASE}" = "latest" ]; then
+if [ "${JDKW_RELEASE}" = "${LATEST_RELEASE}" ]; then
latest_version_json="${TMPDIR:-/tmp}/jdkw-latest-version-$$.$(rand)"
safe_command "curl ${curl_options} -f -k -L -o \"${latest_version_json}\" -H 'Accept: application/json' \"${JDKW_BASE_URI}/releases/latest\""
JDKW_RELEASE=$(sed -e 's/.*"tag_name":"\([^"]*\)".*/\1/' < "${latest_version_json}")
@@ -164,6 +193,10 @@ fi
# Ensure target directory exists
jdkw_path="${JDKW_TARGET}/jdkw/${JDKW_RELEASE}"
+if [ -d "${jdkw_path}" ] && [ "${JDKW_RELEASE}" = "${SNAPSHOT_RELEASE}" ]; then
+ log_out "Removing target snapshot directory ${jdkw_path}"
+ safe_command "rm -rf \"${jdkw_path}\""
+fi
if [ ! -d "${jdkw_path}" ]; then
log_out "Creating target directory ${jdkw_path}"
safe_command "mkdir -p \"${jdkw_path}\""
@@ -172,30 +205,8 @@ fi
# Download the jdk wrapper version
jdkw_impl="jdkw-impl.sh"
jdkw_wrapper="jdk-wrapper.sh"
-download_if_needed "${jdkw_impl}" "${jdkw_path}"
-download_if_needed "${jdkw_wrapper}" "${jdkw_path}"
-
-# Execute the provided command
-
-# Run the command in the backround (with all the trouble that entails)
-# NOTE: Alternatively convert this to an exec if we don't need to output the
-# wrapper mismatch at the end; e.g. make that a hard precondition to running.
-set -m
-trap 'kill -TERM ${impl_pid}' TERM INT
-"${jdkw_path}/${jdkw_impl}" "$@" &
-impl_pid=$!
-fg
-wait ${impl_pid} > /dev/null 2>&1
-wait_result=$?
-if [ ${wait_result} -ne 127 ]; then
- result=${wait_result}
-fi
-trap - TERM INT
-wait ${impl_pid} > /dev/null 2>&1
-wait_result=$?
-if [ ${wait_result} -ne 127 ]; then
- result=${wait_result}
-fi
+obtain_if_needed "${jdkw_impl}" "${jdkw_path}"
+obtain_if_needed "${jdkw_wrapper}" "${jdkw_path}"
# Check whether this wrapper is the one specified for this version
jdkw_download="${jdkw_path}/${jdkw_wrapper}"
@@ -204,6 +215,13 @@ if [ "$(checksum "${jdkw_download}")" != "$(checksum "${jdkw_current}")" ]; then
printf "\e[0;31m[WARNING]\e[0m Your jdk-wrapper.sh file does not match the one in your JDKW_RELEASE.\n"
printf "\e[0;32mUpdate your jdk-wrapper.sh to match by running:\e[0m\n"
printf "cp \"%s\" \"%s\"\n" "${jdkw_download}" "${jdkw_current}"
+ sleep 3
fi
-exit ${result}
+# Execute the provided command
+# NOTE: The requirements proved quite difficult to run this without exec.
+# 1) Exit with the exit status of the child process
+# 2) Allow running the wrapper in the background and terminating the child process
+# 3) Allow the child process to read from standard input when not running in the background
+exec "${jdkw_path}/${jdkw_impl}" "$@"
+
diff --git a/maven/maven-wrapper.properties b/maven/maven-wrapper.properties
index 60c4522..9717dad 100644
--- a/maven/maven-wrapper.properties
+++ b/maven/maven-wrapper.properties
@@ -1,5 +1,5 @@
#Maven download properties
-#Wed Sep 11 15:35:48 PDT 2019
-checksumAlgorithm=SHA1
+#Wed Jan 19 23:16:22 PST 2022
+distributionUrl=https\://repo1.maven.org/maven2/org/apache/maven/apache-maven/3.8.4/apache-maven-3.8.4-bin.zip
verifyDownload=true
-distributionUrl=https\://repo1.maven.org/maven2/org/apache/maven/apache-maven/3.5.4/apache-maven-3.5.4-bin.zip
+checksumAlgorithm=SHA1
diff --git a/pom.xml b/pom.xml
index e1cd6e4..820da59 100644
--- a/pom.xml
+++ b/pom.xml
@@ -18,7 +18,7 @@
com.arpnetworking.build
arpnetworking-parent-pom
- 2.0.5
+ 3.0.9
@@ -68,13 +68,13 @@
- 1.18.3
- 4.0.3
+ 2.0.4
+ 4.7.1
2.2
3.0.2
- 4.13
- 2.23.4
- 1.7.30
+ 4.13.2
+ 4.7.0
+ 1.7.36
diff --git a/spotbugs.exclude.xml b/spotbugs.exclude.xml
index ca51a0d..b203a38 100644
--- a/spotbugs.exclude.xml
+++ b/spotbugs.exclude.xml
@@ -26,7 +26,11 @@
http://findbugs.sourceforge.net/bugDescriptions.html#DLS_DEAD_LOCAL_STORE
-->
-
+
+
+
+
+