From 7bea2d173b2cf5f416b73319de8cc1f86fd74065 Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Tue, 20 Aug 2024 18:06:00 -0400 Subject: [PATCH 1/6] Fix compiler warning Signed-off-by: BJ Hargrave --- .../src/test/java/transformer/test/TestCommandLine.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java b/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java index 0df4629f..4247b15b 100644 --- a/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java +++ b/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java @@ -432,7 +432,7 @@ private void verifyActionInvalidDirectoryRejected(String actionClassName, String private static Map extractSignatureFileEntries(String zipFilePath) throws IOException { try (ZipFile zipFile = new ZipFile(zipFilePath)) { final Enumeration entries = zipFile.entries(); - final Map signatureFilesMap = new HashMap(); + final Map signatureFilesMap = new HashMap<>(); while (entries.hasMoreElements()) { final ZipEntry zipEntry = entries.nextElement(); if (ElementAction.SIGNATURE_FILE_PATTERN.matcher(zipEntry.getName()).matches()) { From 6294145595fed154f150259a2787f091dbbba284 Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Tue, 20 Aug 2024 18:06:26 -0400 Subject: [PATCH 2/6] Fix maven warnings and IDE warnings Signed-off-by: BJ Hargrave --- .../src/test/projects/transform-build-jar-artifact/pom.xml | 3 --- org.eclipse.transformer.cli/pom.xml | 1 + org.eclipse.transformer.parent/pom.xml | 4 +++- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml index 5b86a207..dfdf4d2f 100644 --- a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml +++ b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml @@ -57,9 +57,6 @@ maven-jar-plugin - - false - diff --git a/org.eclipse.transformer.cli/pom.xml b/org.eclipse.transformer.cli/pom.xml index 442c4405..29c8d9f4 100644 --- a/org.eclipse.transformer.cli/pom.xml +++ b/org.eclipse.transformer.cli/pom.xml @@ -100,6 +100,7 @@ jar + diff --git a/org.eclipse.transformer.parent/pom.xml b/org.eclipse.transformer.parent/pom.xml index 1378d754..a3391ed8 100644 --- a/org.eclipse.transformer.parent/pom.xml +++ b/org.eclipse.transformer.parent/pom.xml @@ -102,6 +102,7 @@ jar + ${basedir}/src/it ${basedir}/src/it/settings.xml ${project.build.directory}/it-repo - true ${project.build.directory}/it true @@ -227,6 +227,7 @@ SPDX-License-Identifier: ${project.licenses[0].name} ${revision} ${bnd.version} + ${env.MAVEN_OPTS} */pom.xml @@ -609,6 +610,7 @@ SPDX-License-Identifier: ${project.licenses[0].name} maven-gpg-plugin + ${gpg.pinentrymode} From cb5602d8da3bde709d6504b25a84edb983b9e8f4 Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Tue, 20 Aug 2024 18:05:32 -0400 Subject: [PATCH 3/6] build: Update maven version and maven wrapper version Signed-off-by: BJ Hargrave --- .mvn/wrapper/maven-wrapper.jar | Bin 59925 -> 63028 bytes .mvn/wrapper/maven-wrapper.properties | 8 +- mvnw | 323 +++++++++++++++----------- mvnw.cmd | 33 ++- 4 files changed, 215 insertions(+), 149 deletions(-) diff --git a/.mvn/wrapper/maven-wrapper.jar b/.mvn/wrapper/maven-wrapper.jar index bf82ff01c6cdae4a1bb754a6e062954d77ac5c11..7967f30dd1d25fe1b79a4a6e50e2aaa0e425c02c 100644 GIT binary patch delta 53252 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

&vNik?M&>8{Oc%K{6*Sl5|ig;fC)?_5R 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⩔AYc#;6K^fq;$EQq-nkbqZE%wZDA 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 diff --git a/.mvn/wrapper/maven-wrapper.properties b/.mvn/wrapper/maven-wrapper.properties index ca5ab4ba..9548abd8 100644 --- a/.mvn/wrapper/maven-wrapper.properties +++ b/.mvn/wrapper/maven-wrapper.properties @@ -6,7 +6,7 @@ # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # -# https://www.apache.org/licenses/LICENSE-2.0 +# http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an @@ -14,5 +14,7 @@ # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. -distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.7/apache-maven-3.8.7-bin.zip -wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar +wrapperVersion=3.3.2 +distributionType=bin +distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.9/apache-maven-3.9.9-bin.zip +wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.3.2/maven-wrapper-3.3.2.jar diff --git a/mvnw b/mvnw index b7f06462..5e9618ca 100755 --- a/mvnw +++ b/mvnw @@ -19,7 +19,7 @@ # ---------------------------------------------------------------------------- # ---------------------------------------------------------------------------- -# Apache Maven Wrapper startup batch script, version 3.1.1 +# Apache Maven Wrapper startup batch script, version 3.3.2 # # Required ENV vars: # ------------------ @@ -33,252 +33,297 @@ # MAVEN_SKIP_RC - flag to disable loading of mavenrc files # ---------------------------------------------------------------------------- -if [ -z "$MAVEN_SKIP_RC" ] ; then +if [ -z "$MAVEN_SKIP_RC" ]; then - if [ -f /usr/local/etc/mavenrc ] ; then + if [ -f /usr/local/etc/mavenrc ]; then . /usr/local/etc/mavenrc fi - if [ -f /etc/mavenrc ] ; then + if [ -f /etc/mavenrc ]; then . /etc/mavenrc fi - if [ -f "$HOME/.mavenrc" ] ; then + if [ -f "$HOME/.mavenrc" ]; then . "$HOME/.mavenrc" fi fi # OS specific support. $var _must_ be set to either true or false. -cygwin=false; -darwin=false; +cygwin=false +darwin=false mingw=false -case "`uname`" in - CYGWIN*) cygwin=true ;; - MINGW*) mingw=true;; - Darwin*) darwin=true - # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home - # See https://developer.apple.com/library/mac/qa/qa1170/_index.html - if [ -z "$JAVA_HOME" ]; then - if [ -x "/usr/libexec/java_home" ]; then - JAVA_HOME="`/usr/libexec/java_home`"; export JAVA_HOME - else - JAVA_HOME="/Library/Java/Home"; export JAVA_HOME - fi +case "$(uname)" in +CYGWIN*) cygwin=true ;; +MINGW*) mingw=true ;; +Darwin*) + darwin=true + # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home + # See https://developer.apple.com/library/mac/qa/qa1170/_index.html + if [ -z "$JAVA_HOME" ]; then + if [ -x "/usr/libexec/java_home" ]; then + JAVA_HOME="$(/usr/libexec/java_home)" + export JAVA_HOME + else + JAVA_HOME="/Library/Java/Home" + export JAVA_HOME fi - ;; + fi + ;; esac -if [ -z "$JAVA_HOME" ] ; then - if [ -r /etc/gentoo-release ] ; then - JAVA_HOME=`java-config --jre-home` +if [ -z "$JAVA_HOME" ]; then + if [ -r /etc/gentoo-release ]; then + JAVA_HOME=$(java-config --jre-home) fi fi # For Cygwin, ensure paths are in UNIX format before anything is touched -if $cygwin ; then - [ -n "$JAVA_HOME" ] && - JAVA_HOME=`cygpath --unix "$JAVA_HOME"` - [ -n "$CLASSPATH" ] && - CLASSPATH=`cygpath --path --unix "$CLASSPATH"` +if $cygwin; then + [ -n "$JAVA_HOME" ] \ + && JAVA_HOME=$(cygpath --unix "$JAVA_HOME") + [ -n "$CLASSPATH" ] \ + && CLASSPATH=$(cygpath --path --unix "$CLASSPATH") fi # For Mingw, ensure paths are in UNIX format before anything is touched -if $mingw ; then - [ -n "$JAVA_HOME" ] && - JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" +if $mingw; then + [ -n "$JAVA_HOME" ] && [ -d "$JAVA_HOME" ] \ + && JAVA_HOME="$( + cd "$JAVA_HOME" || ( + echo "cannot cd into $JAVA_HOME." >&2 + exit 1 + ) + pwd + )" fi if [ -z "$JAVA_HOME" ]; then - javaExecutable="`which javac`" - if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then + javaExecutable="$(which javac)" + if [ -n "$javaExecutable" ] && ! [ "$(expr "$javaExecutable" : '\([^ ]*\)')" = "no" ]; then # readlink(1) is not available as standard on Solaris 10. - readLink=`which readlink` - if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then - if $darwin ; then - javaHome="`dirname \"$javaExecutable\"`" - javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" + readLink=$(which readlink) + if [ ! "$(expr "$readLink" : '\([^ ]*\)')" = "no" ]; then + if $darwin; then + javaHome="$(dirname "$javaExecutable")" + javaExecutable="$(cd "$javaHome" && pwd -P)/javac" else - javaExecutable="`readlink -f \"$javaExecutable\"`" + javaExecutable="$(readlink -f "$javaExecutable")" fi - javaHome="`dirname \"$javaExecutable\"`" - javaHome=`expr "$javaHome" : '\(.*\)/bin'` + javaHome="$(dirname "$javaExecutable")" + javaHome=$(expr "$javaHome" : '\(.*\)/bin') JAVA_HOME="$javaHome" export JAVA_HOME fi fi fi -if [ -z "$JAVACMD" ] ; then - if [ -n "$JAVA_HOME" ] ; then - if [ -x "$JAVA_HOME/jre/sh/java" ] ; then +if [ -z "$JAVACMD" ]; then + if [ -n "$JAVA_HOME" ]; then + if [ -x "$JAVA_HOME/jre/sh/java" ]; then # IBM's JDK on AIX uses strange locations for the executables JAVACMD="$JAVA_HOME/jre/sh/java" else JAVACMD="$JAVA_HOME/bin/java" fi else - JAVACMD="`\\unset -f command; \\command -v java`" + JAVACMD="$( + \unset -f command 2>/dev/null + \command -v java + )" fi fi -if [ ! -x "$JAVACMD" ] ; then +if [ ! -x "$JAVACMD" ]; then echo "Error: JAVA_HOME is not defined correctly." >&2 echo " We cannot execute $JAVACMD" >&2 exit 1 fi -if [ -z "$JAVA_HOME" ] ; then - echo "Warning: JAVA_HOME environment variable is not set." +if [ -z "$JAVA_HOME" ]; then + echo "Warning: JAVA_HOME environment variable is not set." >&2 fi # traverses directory structure from process work directory to filesystem root # first directory with .mvn subdirectory is considered project base directory find_maven_basedir() { - if [ -z "$1" ] - then - echo "Path not specified to find_maven_basedir" + if [ -z "$1" ]; then + echo "Path not specified to find_maven_basedir" >&2 return 1 fi basedir="$1" wdir="$1" - while [ "$wdir" != '/' ] ; do - if [ -d "$wdir"/.mvn ] ; then + while [ "$wdir" != '/' ]; do + if [ -d "$wdir"/.mvn ]; then basedir=$wdir break fi # workaround for JBEAP-8937 (on Solaris 10/Sparc) if [ -d "${wdir}" ]; then - wdir=`cd "$wdir/.."; pwd` + wdir=$( + cd "$wdir/.." || exit 1 + pwd + ) fi # end of workaround done - printf '%s' "$(cd "$basedir"; pwd)" + printf '%s' "$( + cd "$basedir" || exit 1 + pwd + )" } # concatenates all lines of a file concat_lines() { if [ -f "$1" ]; then - echo "$(tr -s '\n' ' ' < "$1")" + # Remove \r in case we run on Windows within Git Bash + # and check out the repository with auto CRLF management + # enabled. Otherwise, we may read lines that are delimited with + # \r\n and produce $'-Xarg\r' rather than -Xarg due to word + # splitting rules. + tr -s '\r\n' ' ' <"$1" fi } -BASE_DIR=$(find_maven_basedir "$(dirname $0)") +log() { + if [ "$MVNW_VERBOSE" = true ]; then + printf '%s\n' "$1" + fi +} + +BASE_DIR=$(find_maven_basedir "$(dirname "$0")") if [ -z "$BASE_DIR" ]; then - exit 1; + exit 1 fi -MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}; export MAVEN_PROJECTBASEDIR -if [ "$MVNW_VERBOSE" = true ]; then - echo $MAVEN_PROJECTBASEDIR -fi +MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} +export MAVEN_PROJECTBASEDIR +log "$MAVEN_PROJECTBASEDIR" ########################################################################################## # Extension to allow automatically downloading the maven-wrapper.jar from Maven-central # This allows using the maven wrapper in projects that prohibit checking in binary data. ########################################################################################## -if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found .mvn/wrapper/maven-wrapper.jar" - fi +wrapperJarPath="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" +if [ -r "$wrapperJarPath" ]; then + log "Found $wrapperJarPath" else - if [ "$MVNW_VERBOSE" = true ]; then - echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." - fi - if [ -n "$MVNW_REPOURL" ]; then - wrapperUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar" + log "Couldn't find $wrapperJarPath, downloading it ..." + + if [ -n "$MVNW_REPOURL" ]; then + wrapperUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.3.2/maven-wrapper-3.3.2.jar" + else + wrapperUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.3.2/maven-wrapper-3.3.2.jar" + fi + while IFS="=" read -r key value; do + # Remove '\r' from value to allow usage on windows as IFS does not consider '\r' as a separator ( considers space, tab, new line ('\n'), and custom '=' ) + safeValue=$(echo "$value" | tr -d '\r') + case "$key" in wrapperUrl) + wrapperUrl="$safeValue" + break + ;; + esac + done <"$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties" + log "Downloading from: $wrapperUrl" + + if $cygwin; then + wrapperJarPath=$(cygpath --path --windows "$wrapperJarPath") + fi + + if command -v wget >/dev/null; then + log "Found wget ... using wget" + [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--quiet" + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + wget $QUIET "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" else - wrapperUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar" + wget $QUIET --http-user="$MVNW_USERNAME" --http-password="$MVNW_PASSWORD" "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" fi - while IFS="=" read key value; do - case "$key" in (wrapperUrl) wrapperUrl="$value"; break ;; - esac - done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" - if [ "$MVNW_VERBOSE" = true ]; then - echo "Downloading from: $wrapperUrl" + elif command -v curl >/dev/null; then + log "Found curl ... using curl" + [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--silent" + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + curl $QUIET -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath" + else + curl $QUIET --user "$MVNW_USERNAME:$MVNW_PASSWORD" -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath" fi - wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" + else + log "Falling back to using Java to download" + javaSource="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.java" + javaClass="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.class" + # For Cygwin, switch paths to Windows format before running javac if $cygwin; then - wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` + javaSource=$(cygpath --path --windows "$javaSource") + javaClass=$(cygpath --path --windows "$javaClass") fi - - if command -v wget > /dev/null; then - QUIET="--quiet" - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found wget ... using wget" - QUIET="" - fi - if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then - wget $QUIET "$wrapperUrl" -O "$wrapperJarPath" - else - wget $QUIET --http-user="$MVNW_USERNAME" --http-password="$MVNW_PASSWORD" "$wrapperUrl" -O "$wrapperJarPath" - fi - [ $? -eq 0 ] || rm -f "$wrapperJarPath" - elif command -v curl > /dev/null; then - QUIET="--silent" - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found curl ... using curl" - QUIET="" - fi - if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then - curl $QUIET -o "$wrapperJarPath" "$wrapperUrl" -f -L - else - curl $QUIET --user "$MVNW_USERNAME:$MVNW_PASSWORD" -o "$wrapperJarPath" "$wrapperUrl" -f -L - fi - [ $? -eq 0 ] || rm -f "$wrapperJarPath" - else - if [ "$MVNW_VERBOSE" = true ]; then - echo "Falling back to using Java to download" - fi - javaSource="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" - javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" - # For Cygwin, switch paths to Windows format before running javac - if $cygwin; then - javaSource=`cygpath --path --windows "$javaSource"` - javaClass=`cygpath --path --windows "$javaClass"` - fi - if [ -e "$javaSource" ]; then - if [ ! -e "$javaClass" ]; then - if [ "$MVNW_VERBOSE" = true ]; then - echo " - Compiling MavenWrapperDownloader.java ..." - fi - # Compiling the Java class - ("$JAVA_HOME/bin/javac" "$javaSource") - fi - if [ -e "$javaClass" ]; then - # Running the downloader - if [ "$MVNW_VERBOSE" = true ]; then - echo " - Running MavenWrapperDownloader.java ..." - fi - ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") - fi - fi + if [ -e "$javaSource" ]; then + if [ ! -e "$javaClass" ]; then + log " - Compiling MavenWrapperDownloader.java ..." + ("$JAVA_HOME/bin/javac" "$javaSource") + fi + if [ -e "$javaClass" ]; then + log " - Running MavenWrapperDownloader.java ..." + ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$wrapperUrl" "$wrapperJarPath") || rm -f "$wrapperJarPath" + fi fi + fi fi ########################################################################################## # End of extension ########################################################################################## +# If specified, validate the SHA-256 sum of the Maven wrapper jar file +wrapperSha256Sum="" +while IFS="=" read -r key value; do + case "$key" in wrapperSha256Sum) + wrapperSha256Sum=$value + break + ;; + esac +done <"$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties" +if [ -n "$wrapperSha256Sum" ]; then + wrapperSha256Result=false + if command -v sha256sum >/dev/null; then + if echo "$wrapperSha256Sum $wrapperJarPath" | sha256sum -c >/dev/null 2>&1; then + wrapperSha256Result=true + fi + elif command -v shasum >/dev/null; then + if echo "$wrapperSha256Sum $wrapperJarPath" | shasum -a 256 -c >/dev/null 2>&1; then + wrapperSha256Result=true + fi + else + echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available." >&2 + echo "Please install either command, or disable validation by removing 'wrapperSha256Sum' from your maven-wrapper.properties." >&2 + exit 1 + fi + if [ $wrapperSha256Result = false ]; then + echo "Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised." >&2 + echo "Investigate or delete $wrapperJarPath to attempt a clean download." >&2 + echo "If you updated your Maven version, you need to update the specified wrapperSha256Sum property." >&2 + exit 1 + fi +fi + MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" # For Cygwin, switch paths to Windows format before running java if $cygwin; then - [ -n "$JAVA_HOME" ] && - JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` - [ -n "$CLASSPATH" ] && - CLASSPATH=`cygpath --path --windows "$CLASSPATH"` - [ -n "$MAVEN_PROJECTBASEDIR" ] && - MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` + [ -n "$JAVA_HOME" ] \ + && JAVA_HOME=$(cygpath --path --windows "$JAVA_HOME") + [ -n "$CLASSPATH" ] \ + && CLASSPATH=$(cygpath --path --windows "$CLASSPATH") + [ -n "$MAVEN_PROJECTBASEDIR" ] \ + && MAVEN_PROJECTBASEDIR=$(cygpath --path --windows "$MAVEN_PROJECTBASEDIR") fi # Provide a "standardized" way to retrieve the CLI args that will # work with both Windows and non-Windows executions. -MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" +MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $*" export MAVEN_CMD_LINE_ARGS WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain +# shellcheck disable=SC2086 # safe args exec "$JAVACMD" \ $MAVEN_OPTS \ $MAVEN_DEBUG_OPTS \ diff --git a/mvnw.cmd b/mvnw.cmd index cba1f040..1204076a 100644 --- a/mvnw.cmd +++ b/mvnw.cmd @@ -18,7 +18,7 @@ @REM ---------------------------------------------------------------------------- @REM ---------------------------------------------------------------------------- -@REM Apache Maven Wrapper startup batch script, version 3.1.1 +@REM Apache Maven Wrapper startup batch script, version 3.3.2 @REM @REM Required ENV vars: @REM JAVA_HOME - location of a JDK home dir @@ -59,22 +59,22 @@ set ERROR_CODE=0 @REM ==== START VALIDATION ==== if not "%JAVA_HOME%" == "" goto OkJHome -echo. +echo. >&2 echo Error: JAVA_HOME not found in your environment. >&2 echo Please set the JAVA_HOME variable in your environment to match the >&2 echo location of your Java installation. >&2 -echo. +echo. >&2 goto error :OkJHome if exist "%JAVA_HOME%\bin\java.exe" goto init -echo. +echo. >&2 echo Error: JAVA_HOME is set to an invalid directory. >&2 echo JAVA_HOME = "%JAVA_HOME%" >&2 echo Please set the JAVA_HOME variable in your environment to match the >&2 echo location of your Java installation. >&2 -echo. +echo. >&2 goto error @REM ==== END VALIDATION ==== @@ -119,7 +119,7 @@ SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain -set WRAPPER_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar" +set WRAPPER_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.3.2/maven-wrapper-3.3.2.jar" FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( IF "%%A"=="wrapperUrl" SET WRAPPER_URL=%%B @@ -133,7 +133,7 @@ if exist %WRAPPER_JAR% ( ) ) else ( if not "%MVNW_REPOURL%" == "" ( - SET WRAPPER_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar" + SET WRAPPER_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.3.2/maven-wrapper-3.3.2.jar" ) if "%MVNW_VERBOSE%" == "true" ( echo Couldn't find %WRAPPER_JAR%, downloading it ... @@ -153,6 +153,25 @@ if exist %WRAPPER_JAR% ( ) @REM End of extension +@REM If specified, validate the SHA-256 sum of the Maven wrapper jar file +SET WRAPPER_SHA_256_SUM="" +FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( + IF "%%A"=="wrapperSha256Sum" SET WRAPPER_SHA_256_SUM=%%B +) +IF NOT %WRAPPER_SHA_256_SUM%=="" ( + powershell -Command "&{"^ + "Import-Module $PSHOME\Modules\Microsoft.PowerShell.Utility -Function Get-FileHash;"^ + "$hash = (Get-FileHash \"%WRAPPER_JAR%\" -Algorithm SHA256).Hash.ToLower();"^ + "If('%WRAPPER_SHA_256_SUM%' -ne $hash){"^ + " Write-Error 'Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised.';"^ + " Write-Error 'Investigate or delete %WRAPPER_JAR% to attempt a clean download.';"^ + " Write-Error 'If you updated your Maven version, you need to update the specified wrapperSha256Sum property.';"^ + " exit 1;"^ + "}"^ + "}" + if ERRORLEVEL 1 goto error +) + @REM Provide a "standardized" way to retrieve the CLI args that will @REM work with both Windows and non-Windows executions. set MAVEN_CMD_LINE_ARGS=%* From 4db59471ca6a5f9af65af1624ef5d0456bf547b9 Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Tue, 20 Aug 2024 18:16:55 -0400 Subject: [PATCH 4/6] bnd: Update to Bnd 7.0.0 and Java 17 This also means dropping support for Java versions below 17. Signed-off-by: BJ Hargrave --- .github/workflows/cibuild.yml | 3 +-- .../.settings/org.eclipse.jdt.core.prefs | 8 +++---- .../.settings/org.eclipse.jdt.core.prefs | 8 +++---- .../transformer-maven-plugin/README.md | 16 -------------- .../projects/transform-build-artifact/pom.xml | 3 +-- .../transform-build-jar-artifact/pom.xml | 3 +-- .../.settings/org.eclipse.jdt.core.prefs | 8 +++---- .../.settings/org.eclipse.jdt.core.prefs | 8 +++---- org.eclipse.transformer.parent/pom.xml | 21 ++++--------------- .../.settings/org.eclipse.jdt.core.prefs | 8 +++---- 10 files changed, 27 insertions(+), 59 deletions(-) diff --git a/.github/workflows/cibuild.yml b/.github/workflows/cibuild.yml index eeeb4194..8b4c0396 100644 --- a/.github/workflows/cibuild.yml +++ b/.github/workflows/cibuild.yml @@ -49,8 +49,7 @@ jobs: os: - 'ubuntu-latest' java: - - '8' - - '11' + - '21' include: - os: 'ubuntu-latest' java: '17' diff --git a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/.settings/org.eclipse.jdt.core.prefs b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/.settings/org.eclipse.jdt.core.prefs index e8532c39..c772cad8 100644 --- a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/.settings/org.eclipse.jdt.core.prefs +++ b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/.settings/org.eclipse.jdt.core.prefs @@ -30,9 +30,9 @@ org.eclipse.jdt.core.compiler.annotation.nullable.secondary= org.eclipse.jdt.core.compiler.annotation.nullanalysis=disabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate -org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve -org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate @@ -72,7 +72,7 @@ org.eclipse.jdt.core.compiler.problem.invalidJavadocTagsVisibility=public org.eclipse.jdt.core.compiler.problem.localVariableHiding=ignore org.eclipse.jdt.core.compiler.problem.methodWithConstructorName=warning org.eclipse.jdt.core.compiler.problem.missingDefaultCase=ignore -org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=ignore +org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=warning org.eclipse.jdt.core.compiler.problem.missingEnumCaseDespiteDefault=disabled org.eclipse.jdt.core.compiler.problem.missingHashCodeMethod=warning org.eclipse.jdt.core.compiler.problem.missingJavadocComments=ignore @@ -150,7 +150,7 @@ org.eclipse.jdt.core.compiler.problem.unusedWarningToken=ignore org.eclipse.jdt.core.compiler.problem.varargsArgumentNeedCast=warning org.eclipse.jdt.core.compiler.processAnnotations=disabled org.eclipse.jdt.core.compiler.release=enabled -org.eclipse.jdt.core.compiler.source=1.8 +org.eclipse.jdt.core.compiler.source=17 org.eclipse.jdt.core.compiler.taskCaseSensitive=enabled org.eclipse.jdt.core.compiler.taskPriorities=NORMAL,NORMAL org.eclipse.jdt.core.compiler.taskTags=TODO,FIXME diff --git a/maven-plugins/transformer-maven-plugin/.settings/org.eclipse.jdt.core.prefs b/maven-plugins/transformer-maven-plugin/.settings/org.eclipse.jdt.core.prefs index e8532c39..c772cad8 100644 --- a/maven-plugins/transformer-maven-plugin/.settings/org.eclipse.jdt.core.prefs +++ b/maven-plugins/transformer-maven-plugin/.settings/org.eclipse.jdt.core.prefs @@ -30,9 +30,9 @@ org.eclipse.jdt.core.compiler.annotation.nullable.secondary= org.eclipse.jdt.core.compiler.annotation.nullanalysis=disabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate -org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve -org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate @@ -72,7 +72,7 @@ org.eclipse.jdt.core.compiler.problem.invalidJavadocTagsVisibility=public org.eclipse.jdt.core.compiler.problem.localVariableHiding=ignore org.eclipse.jdt.core.compiler.problem.methodWithConstructorName=warning org.eclipse.jdt.core.compiler.problem.missingDefaultCase=ignore -org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=ignore +org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=warning org.eclipse.jdt.core.compiler.problem.missingEnumCaseDespiteDefault=disabled org.eclipse.jdt.core.compiler.problem.missingHashCodeMethod=warning org.eclipse.jdt.core.compiler.problem.missingJavadocComments=ignore @@ -150,7 +150,7 @@ org.eclipse.jdt.core.compiler.problem.unusedWarningToken=ignore org.eclipse.jdt.core.compiler.problem.varargsArgumentNeedCast=warning org.eclipse.jdt.core.compiler.processAnnotations=disabled org.eclipse.jdt.core.compiler.release=enabled -org.eclipse.jdt.core.compiler.source=1.8 +org.eclipse.jdt.core.compiler.source=17 org.eclipse.jdt.core.compiler.taskCaseSensitive=enabled org.eclipse.jdt.core.compiler.taskPriorities=NORMAL,NORMAL org.eclipse.jdt.core.compiler.taskTags=TODO,FIXME diff --git a/maven-plugins/transformer-maven-plugin/README.md b/maven-plugins/transformer-maven-plugin/README.md index 35765ad6..99be8683 100644 --- a/maven-plugins/transformer-maven-plugin/README.md +++ b/maven-plugins/transformer-maven-plugin/README.md @@ -8,8 +8,6 @@ This plugin contains the following goals: - [`transform`](#transform-goal) - [`help`](#help-goal) -__Note__: if you are using Java 21 or later see [Using Java 21 or later](#java-21-or-later). - ## `jar` Goal The `jar` goal operates at the JAR file level and transforms the specified input artifact into a project artifact. @@ -253,17 +251,3 @@ It is therefore necessary to configure the `maven-jar-plugin` as follows: The `help` goal displays help about the goals of the plugin. Call `mvn transformer:help -Ddetail=true -Dgoal=` to display configuration details for the specified goal. - -## Java 21 or later - -If you are using Java 21 or later you will need to configure the Maven plugin to use a specific version of the `biz.aQute.bndlib` dependency. - -For example: - -```xml - - biz.aQute.bnd - biz.aQute.bndlib - 7.0.0 - -``` diff --git a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-artifact/pom.xml b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-artifact/pom.xml index 085fc0bd..90008cdf 100644 --- a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-artifact/pom.xml +++ b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-artifact/pom.xml @@ -23,8 +23,7 @@ UTF-8 - 1.8 - 1.8 + 17 diff --git a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml index dfdf4d2f..d50f7b17 100644 --- a/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml +++ b/maven-plugins/transformer-maven-plugin/src/test/projects/transform-build-jar-artifact/pom.xml @@ -23,8 +23,7 @@ UTF-8 - 1.8 - 1.8 + 17 diff --git a/org.eclipse.transformer.cli/.settings/org.eclipse.jdt.core.prefs b/org.eclipse.transformer.cli/.settings/org.eclipse.jdt.core.prefs index e8532c39..c772cad8 100644 --- a/org.eclipse.transformer.cli/.settings/org.eclipse.jdt.core.prefs +++ b/org.eclipse.transformer.cli/.settings/org.eclipse.jdt.core.prefs @@ -30,9 +30,9 @@ org.eclipse.jdt.core.compiler.annotation.nullable.secondary= org.eclipse.jdt.core.compiler.annotation.nullanalysis=disabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate -org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve -org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate @@ -72,7 +72,7 @@ org.eclipse.jdt.core.compiler.problem.invalidJavadocTagsVisibility=public org.eclipse.jdt.core.compiler.problem.localVariableHiding=ignore org.eclipse.jdt.core.compiler.problem.methodWithConstructorName=warning org.eclipse.jdt.core.compiler.problem.missingDefaultCase=ignore -org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=ignore +org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=warning org.eclipse.jdt.core.compiler.problem.missingEnumCaseDespiteDefault=disabled org.eclipse.jdt.core.compiler.problem.missingHashCodeMethod=warning org.eclipse.jdt.core.compiler.problem.missingJavadocComments=ignore @@ -150,7 +150,7 @@ org.eclipse.jdt.core.compiler.problem.unusedWarningToken=ignore org.eclipse.jdt.core.compiler.problem.varargsArgumentNeedCast=warning org.eclipse.jdt.core.compiler.processAnnotations=disabled org.eclipse.jdt.core.compiler.release=enabled -org.eclipse.jdt.core.compiler.source=1.8 +org.eclipse.jdt.core.compiler.source=17 org.eclipse.jdt.core.compiler.taskCaseSensitive=enabled org.eclipse.jdt.core.compiler.taskPriorities=NORMAL,NORMAL org.eclipse.jdt.core.compiler.taskTags=TODO,FIXME diff --git a/org.eclipse.transformer.jakarta/.settings/org.eclipse.jdt.core.prefs b/org.eclipse.transformer.jakarta/.settings/org.eclipse.jdt.core.prefs index e8532c39..c772cad8 100644 --- a/org.eclipse.transformer.jakarta/.settings/org.eclipse.jdt.core.prefs +++ b/org.eclipse.transformer.jakarta/.settings/org.eclipse.jdt.core.prefs @@ -30,9 +30,9 @@ org.eclipse.jdt.core.compiler.annotation.nullable.secondary= org.eclipse.jdt.core.compiler.annotation.nullanalysis=disabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate -org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve -org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate @@ -72,7 +72,7 @@ org.eclipse.jdt.core.compiler.problem.invalidJavadocTagsVisibility=public org.eclipse.jdt.core.compiler.problem.localVariableHiding=ignore org.eclipse.jdt.core.compiler.problem.methodWithConstructorName=warning org.eclipse.jdt.core.compiler.problem.missingDefaultCase=ignore -org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=ignore +org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=warning org.eclipse.jdt.core.compiler.problem.missingEnumCaseDespiteDefault=disabled org.eclipse.jdt.core.compiler.problem.missingHashCodeMethod=warning org.eclipse.jdt.core.compiler.problem.missingJavadocComments=ignore @@ -150,7 +150,7 @@ org.eclipse.jdt.core.compiler.problem.unusedWarningToken=ignore org.eclipse.jdt.core.compiler.problem.varargsArgumentNeedCast=warning org.eclipse.jdt.core.compiler.processAnnotations=disabled org.eclipse.jdt.core.compiler.release=enabled -org.eclipse.jdt.core.compiler.source=1.8 +org.eclipse.jdt.core.compiler.source=17 org.eclipse.jdt.core.compiler.taskCaseSensitive=enabled org.eclipse.jdt.core.compiler.taskPriorities=NORMAL,NORMAL org.eclipse.jdt.core.compiler.taskTags=TODO,FIXME diff --git a/org.eclipse.transformer.parent/pom.xml b/org.eclipse.transformer.parent/pom.xml index a3391ed8..e98edd08 100644 --- a/org.eclipse.transformer.parent/pom.xml +++ b/org.eclipse.transformer.parent/pom.xml @@ -25,11 +25,9 @@ 0.6.0-SNAPSHOT UTF-8 UTF-8 - 1.8 - 8 - ${java.version} - ${java.version} - 6.4.0 + 17 + ${java.release} + 7.0.0 5.11.0 3.26.3 2.10.0 @@ -221,8 +219,6 @@ SPDX-License-Identifier: ${project.licenses[0].name} ${project.build.sourceEncoding} ${project.reporting.outputEncoding} - ${maven.compiler.source} - ${maven.compiler.target} ${maven.compiler.release} ${revision} ${bnd.version} @@ -575,15 +571,6 @@ SPDX-License-Identifier: ${project.licenses[0].name} - - java-release - - [9,) - - - ${java.release} - - pinentrymode-loopback @@ -635,7 +622,7 @@ SPDX-License-Identifier: ${project.licenses[0].name} bnd-snapshot - 7.0.0-SNAPSHOT + 7.1.0-SNAPSHOT diff --git a/org.eclipse.transformer/.settings/org.eclipse.jdt.core.prefs b/org.eclipse.transformer/.settings/org.eclipse.jdt.core.prefs index e8532c39..c772cad8 100644 --- a/org.eclipse.transformer/.settings/org.eclipse.jdt.core.prefs +++ b/org.eclipse.transformer/.settings/org.eclipse.jdt.core.prefs @@ -30,9 +30,9 @@ org.eclipse.jdt.core.compiler.annotation.nullable.secondary= org.eclipse.jdt.core.compiler.annotation.nullanalysis=disabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate -org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve -org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate @@ -72,7 +72,7 @@ org.eclipse.jdt.core.compiler.problem.invalidJavadocTagsVisibility=public org.eclipse.jdt.core.compiler.problem.localVariableHiding=ignore org.eclipse.jdt.core.compiler.problem.methodWithConstructorName=warning org.eclipse.jdt.core.compiler.problem.missingDefaultCase=ignore -org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=ignore +org.eclipse.jdt.core.compiler.problem.missingDeprecatedAnnotation=warning org.eclipse.jdt.core.compiler.problem.missingEnumCaseDespiteDefault=disabled org.eclipse.jdt.core.compiler.problem.missingHashCodeMethod=warning org.eclipse.jdt.core.compiler.problem.missingJavadocComments=ignore @@ -150,7 +150,7 @@ org.eclipse.jdt.core.compiler.problem.unusedWarningToken=ignore org.eclipse.jdt.core.compiler.problem.varargsArgumentNeedCast=warning org.eclipse.jdt.core.compiler.processAnnotations=disabled org.eclipse.jdt.core.compiler.release=enabled -org.eclipse.jdt.core.compiler.source=1.8 +org.eclipse.jdt.core.compiler.source=17 org.eclipse.jdt.core.compiler.taskCaseSensitive=enabled org.eclipse.jdt.core.compiler.taskPriorities=NORMAL,NORMAL org.eclipse.jdt.core.compiler.taskTags=TODO,FIXME From caaea4361fddbad973080c04d5c2e67d4a51a31f Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Wed, 21 Aug 2024 17:24:39 -0400 Subject: [PATCH 5/6] java 17: exploit new language features Also, clean up code based upon IDE suggestions. Signed-off-by: BJ Hargrave --- .../analyzer/TransformerAnalyzerPlugin.java | 6 +- .../analyzer/TransformerVerifierPlugin.java | 6 +- .../maven/AbstractTransformerMojo.java | 2 +- .../transformer/maven/TransformerJarMojo.java | 6 +- .../TransformerMavenLifecycleParticipant.java | 4 +- .../maven/TransformerMojoOptions.java | 66 ++++---------- .../transformer/maven/TransformerRunMojo.java | 43 ++++----- .../maven/TransformerRunMojoTest.java | 4 +- .../transformer/test/TestCommandLine.java | 6 +- .../transformer/ImmediateRuleData.java | 11 +-- .../transformer/TransformProperties.java | 16 ++-- .../org/eclipse/transformer/Transformer.java | 22 +++-- .../transformer/action/ActionContext.java | 13 +-- .../eclipse/transformer/action/ByteData.java | 3 - .../action/impl/ActionContextImpl.java | 52 ----------- .../transformer/action/impl/ActionImpl.java | 6 +- .../action/impl/ClassActionImpl.java | 21 ++--- .../action/impl/ContainerActionImpl.java | 2 +- .../action/impl/ManifestActionImpl.java | 10 +-- .../action/impl/SignatureRuleImpl.java | 2 +- .../action/impl/ZipActionImpl.java | 12 +-- .../transformer/test/ClassActionTest.java | 7 +- .../transformer/test/RenameActionTest.java | 3 +- .../java/transformer/test/SelectionTests.java | 19 ++-- .../transformer/test/TestTransformClass.java | 70 +++++---------- .../test/TestTransformManifest.java | 87 ++++++++----------- .../test/TestTransformPropertiesFile.java | 3 +- .../test/TestTransformServiceConfig.java | 7 +- .../transformer/test/TestTransformXML.java | 16 +--- .../test/TestTransformerImmediateRenames.java | 12 +-- .../transformer/test/TestTransformerJava.java | 7 +- .../test/TestTransformerMultiRenames.java | 8 +- .../test/TestTransformerMultiText.java | 27 +++--- .../test/java/transformer/test/TestUtils.java | 41 +++------ .../transformer/test/util/BiDiMapImpl.java | 18 ++-- .../test/util/CaptureLoggerImpl.java | 21 ++--- .../java/transformer/test/util/ClassData.java | 3 +- .../transformer/test/util/SetDeltaImpl.java | 6 +- 38 files changed, 225 insertions(+), 443 deletions(-) delete mode 100644 org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionContextImpl.java diff --git a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerAnalyzerPlugin.java b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerAnalyzerPlugin.java index acbb88ac..6adec932 100644 --- a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerAnalyzerPlugin.java +++ b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerAnalyzerPlugin.java @@ -21,9 +21,9 @@ @ExternalPlugin(name = "Transformer", objectClass = AnalyzerPlugin.class) public class TransformerAnalyzerPlugin extends BaseTransformerPlugin implements AnalyzerPlugin { public TransformerAnalyzerPlugin() { - /** - * We want to run before other AnalyzerPlugins so they will operate on - * the transformed classes and resources. + /* + We want to run before other AnalyzerPlugins so they will operate on + the transformed classes and resources. */ super(-10_000); } diff --git a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerVerifierPlugin.java b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerVerifierPlugin.java index fd33df59..29287bb4 100644 --- a/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerVerifierPlugin.java +++ b/bnd-plugins/org.eclipse.transformer.bnd.analyzer/src/main/java/org/eclipse/transformer/bnd/analyzer/TransformerVerifierPlugin.java @@ -21,9 +21,9 @@ @ExternalPlugin(name = "Transformer", objectClass = VerifierPlugin.class) public class TransformerVerifierPlugin extends BaseTransformerPlugin implements VerifierPlugin { public TransformerVerifierPlugin() { - /** - * We want to run after other VerifierPlugins so we will operate on the - * final classes and resources. + /* + We want to run after other VerifierPlugins so we will operate on the + final classes and resources. */ super(10_000); } diff --git a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/AbstractTransformerMojo.java b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/AbstractTransformerMojo.java index 63bb3fee..9f561b30 100644 --- a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/AbstractTransformerMojo.java +++ b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/AbstractTransformerMojo.java @@ -79,7 +79,7 @@ public boolean skip() { // Exit without generating anything if this project is not a known // packaging type. Probably it's just a parent project. if (!getPackagingTypes().contains(getProject().getPackaging())) { - getLogger().debug("skip project with packaging=" + getProject().getPackaging()); + getLogger().debug("skip project with packaging={}", getProject().getPackaging()); return true; } diff --git a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerJarMojo.java b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerJarMojo.java index 9cd9c3ad..cb3cfae3 100644 --- a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerJarMojo.java +++ b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerJarMojo.java @@ -290,16 +290,16 @@ private TransformerArtifact prepareArtifactDescription(TransformerArtifact artif List firstPass = dependencies.stream() .filter(dependency -> Objects.equals(artifactDescription.getGroupId(), dependency.getGroupId()) && Objects.equals(artifactDescription.getArtifactId(), dependency.getArtifactId())) - .collect(toList()); + .toList(); Optional matchingDependency = firstPass.stream() .filter(dependency -> Objects.equals(artifactDescription.getClassifier(), dependency.getClassifier()) && Objects.equals(artifactDescription.getType(), dependency.getType())) .findFirst(); - if (!matchingDependency.isPresent()) { + if (matchingDependency.isEmpty()) { matchingDependency = firstPass.stream() .findFirst(); - if (!matchingDependency.isPresent()) { + if (matchingDependency.isEmpty()) { throw new MojoExecutionException(String.format( "No version found for artifact %s:%s in project, dependencies, or dependency management", artifactDescription.getGroupId(), artifactDescription.getArtifactId())); diff --git a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMavenLifecycleParticipant.java b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMavenLifecycleParticipant.java index d6baa2e0..63a48a56 100644 --- a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMavenLifecycleParticipant.java +++ b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMavenLifecycleParticipant.java @@ -178,11 +178,11 @@ public static String extractClassifier(PluginExecution execution) { Optional rootConfiguration = Optional.ofNullable((Xpp3Dom) execution.getConfiguration()); Optional classifierConfiguration = rootConfiguration .map(configuration -> configuration.getChild("classifier")); - if (!classifierConfiguration.isPresent()) { + if (classifierConfiguration.isEmpty()) { classifierConfiguration = rootConfiguration.map(configuration -> configuration.getChild("artifact")) .map(configuration -> configuration.getChild("classifier")); } - if (!classifierConfiguration.isPresent()) { + if (classifierConfiguration.isEmpty()) { return defaultClassifier(execution); } diff --git a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMojoOptions.java b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMojoOptions.java index ee09d92b..a6bfe2bf 100644 --- a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMojoOptions.java +++ b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerMojoOptions.java @@ -63,59 +63,29 @@ private static List condition(List values) { @Override public List getOptionValues(AppOption option) { - List values; - switch (option) { - case RULES_BUNDLES : - values = rules.getBundles(); - break; - case RULES_DIRECT : - values = rules.getDirects(); - break; - case RULES_IMMEDIATE_DATA : - values = rules.getImmediates(); - break; - case RULES_MASTER_TEXT : - values = rules.getTexts(); - break; - case RULES_PER_CLASS_CONSTANT : - values = rules.getPerClassConstants(); - break; - case RULES_RENAMES : - values = rules.getRenames(); - break; - case RULES_SELECTIONS : - values = rules.getSelections(); - break; - case RULES_VERSIONS : - values = rules.getVersions(); - break; - default : - values = null; - break; - } + List values = switch (option) { + case RULES_BUNDLES -> rules.getBundles(); + case RULES_DIRECT -> rules.getDirects(); + case RULES_IMMEDIATE_DATA -> rules.getImmediates(); + case RULES_MASTER_TEXT -> rules.getTexts(); + case RULES_PER_CLASS_CONSTANT -> rules.getPerClassConstants(); + case RULES_RENAMES -> rules.getRenames(); + case RULES_SELECTIONS -> rules.getSelections(); + case RULES_VERSIONS -> rules.getVersions(); + default -> null; + }; return condition(values); } @Override public boolean hasOption(AppOption option) { - boolean has; - switch (option) { - case OVERWRITE : - has = rules.isOverwrite(); - break; - case INVERT : - has = rules.isInvert(); - break; - case WIDEN_ARCHIVE_NESTING : - has = rules.isWiden(); - break; - case STRIP_SIGNATURES : - has = rules.isStripSignatures(); - break; - default : - has = TransformOptions.super.hasOption(option); - break; - } + boolean has = switch (option) { + case OVERWRITE -> rules.isOverwrite(); + case INVERT -> rules.isInvert(); + case WIDEN_ARCHIVE_NESTING -> rules.isWiden(); + case STRIP_SIGNATURES -> rules.isStripSignatures(); + default -> TransformOptions.super.hasOption(option); + }; return has; } diff --git a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerRunMojo.java b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerRunMojo.java index 6ae14943..87db741d 100644 --- a/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerRunMojo.java +++ b/maven-plugins/transformer-maven-plugin/src/main/java/org/eclipse/transformer/maven/TransformerRunMojo.java @@ -119,7 +119,7 @@ public void execute() throws MojoFailureException, MojoExecutionException { */ public void transform(final Artifact sourceArtifact) throws MojoFailureException, MojoExecutionException { final String sourceClassifier = sourceArtifact.getClassifier(); - final String targetClassifier = (sourceClassifier == null || sourceClassifier.length() == 0) ? this.classifier + final String targetClassifier = (sourceClassifier == null || sourceClassifier.isEmpty()) ? this.classifier : sourceClassifier + "-" + this.classifier; final File targetFile = new File(outputDirectory, sourceArtifact.getArtifactId() + "-" + targetClassifier + "-" @@ -129,36 +129,25 @@ public void transform(final Artifact sourceArtifact) throws MojoFailureException final Function ruleLoader = JakartaTransform.getRuleLoader(); @Override public boolean hasOption(AppOption option) { - switch (option) { - case OVERWRITE : - return overwrite; - case INVERT : - return invert; - case STRIP_SIGNATURES: - return stripSignatures; - default : - return TransformOptions.super.hasOption(option); - } + return switch (option) { + case OVERWRITE -> overwrite; + case INVERT -> invert; + case STRIP_SIGNATURES -> stripSignatures; + default -> TransformOptions.super.hasOption(option); + }; } @Override public String getOptionValue(AppOption option) { - switch (option) { - case RULES_RENAMES : - return emptyAsNull(rulesRenamesUri); - case RULES_VERSIONS : - return emptyAsNull(rulesVersionUri); - case RULES_BUNDLES : - return emptyAsNull(rulesBundlesUri); - case RULES_DIRECT : - return emptyAsNull(rulesDirectUri); - case RULES_MASTER_TEXT : - return emptyAsNull(rulesXmlsUri); - case RULES_PER_CLASS_CONSTANT : - return emptyAsNull(rulesPerClassConstantUri); - default : - return null; - } + return switch (option) { + case RULES_RENAMES -> emptyAsNull(rulesRenamesUri); + case RULES_VERSIONS -> emptyAsNull(rulesVersionUri); + case RULES_BUNDLES -> emptyAsNull(rulesBundlesUri); + case RULES_DIRECT -> emptyAsNull(rulesDirectUri); + case RULES_MASTER_TEXT -> emptyAsNull(rulesXmlsUri); + case RULES_PER_CLASS_CONSTANT -> emptyAsNull(rulesPerClassConstantUri); + default -> null; + }; } @Override diff --git a/maven-plugins/transformer-maven-plugin/src/test/java/org/eclipse/transformer/maven/TransformerRunMojoTest.java b/maven-plugins/transformer-maven-plugin/src/test/java/org/eclipse/transformer/maven/TransformerRunMojoTest.java index 443c9eb3..5415c7c5 100644 --- a/maven-plugins/transformer-maven-plugin/src/test/java/org/eclipse/transformer/maven/TransformerRunMojoTest.java +++ b/maven-plugins/transformer-maven-plugin/src/test/java/org/eclipse/transformer/maven/TransformerRunMojoTest.java @@ -146,7 +146,7 @@ public void testMultipleArtifactTransformerPlugin() throws Exception { .equals("zip") && a.getArtifactId() .equals("simple-service"))) - .map(a -> a.getClassifier()) + .map(Artifact::getClassifier) .collect(Collectors.toSet()); assertEquals(6, mavenProject.getAttachedArtifacts() @@ -260,7 +260,7 @@ private static File createService(String packaging, File targetDirectory) throws final File tempFile = File.createTempFile("service", "." + packaging); tempFile.delete(); - final Archive archive; + final Archive archive; if (packaging.equals("jar")) { archive = ShrinkWrap.create(JavaArchive.class, "service." + packaging) .addClass(EchoService.class); diff --git a/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java b/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java index 4247b15b..9b507d7d 100644 --- a/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java +++ b/org.eclipse.transformer.cli/src/test/java/transformer/test/TestCommandLine.java @@ -218,8 +218,7 @@ void zip_non_UTF_8_encoding() throws Exception { transformer.transform(); Changes lastActiveChanges = transformer.getLastActiveChanges(); - if (lastActiveChanges instanceof ContainerChanges) { - ContainerChanges containerChanges = (ContainerChanges) lastActiveChanges; + if (lastActiveChanges instanceof ContainerChanges containerChanges) { int numDuplicated = containerChanges.getAllDuplicated(); int numFailed = containerChanges.getAllFailed(); @@ -391,8 +390,7 @@ private void verifyAction(String actionClassName, String inputFileName, String o transformer.transform(); Changes lastActiveChanges = transformer.getLastActiveChanges(); - if (lastActiveChanges instanceof ContainerChanges) { - ContainerChanges containerChanges = (ContainerChanges) lastActiveChanges; + if (lastActiveChanges instanceof ContainerChanges containerChanges) { int numDuplicated = containerChanges.getAllDuplicated(); int numFailed = containerChanges.getAllFailed(); diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/ImmediateRuleData.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/ImmediateRuleData.java index b615613e..6043e64d 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/ImmediateRuleData.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/ImmediateRuleData.java @@ -11,14 +11,5 @@ package org.eclipse.transformer; -public class ImmediateRuleData { - public final AppOption target; - public final String key; - public final String value; - - public ImmediateRuleData(AppOption target, String key, String value) { - this.target = target; - this.key = key; - this.value = value; - } +public record ImmediateRuleData(AppOption target, String key, String value) { } diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/TransformProperties.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/TransformProperties.java index bc6eb12b..d76bab4d 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/TransformProperties.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/TransformProperties.java @@ -148,7 +148,7 @@ public static void setPackageVersions( } else if ( nextChar == ';' ) { // The length test guards against 'p=v;a1=v1;;a2=v2' - if ( versionBuilder.length() != 0 ) { + if (!versionBuilder.isEmpty()) { setVersion( newPackageName, newVersion, nameBuilder, versionBuilder, @@ -165,7 +165,7 @@ public static void setPackageVersions( // // See issue #300. - if ( nameBuilder.length() != 0 ) { + if (!nameBuilder.isEmpty()) { throw new IllegalArgumentException("Package version syntax error: Version missing for package [ " + newPackageName + " ] and attribute [ " + nameBuilder.toString() + " ]"); } } @@ -184,7 +184,7 @@ public static void setPackageVersions( // end with a ';', in which case the builders will be empty, // and there is no update to be done. - if ( versionBuilder.length() != 0 ) { + if (!versionBuilder.isEmpty()) { setVersion( newPackageName, newVersion, nameBuilder, versionBuilder, @@ -206,7 +206,7 @@ public static void setVersion( Map> specificPackageVersions) { String versionText; - if ( versionBuilder.length() == 0 ) { + if (versionBuilder.isEmpty()) { throw new IllegalArgumentException("Package version syntax error: No version in [ " + newVersion + " ]"); } else { versionText = versionBuilder.toString(); @@ -214,7 +214,7 @@ public static void setVersion( } String propertyName; - if ( nameBuilder.length() == 0 ) { + if (nameBuilder.isEmpty()) { propertyName = null; } else { propertyName = nameBuilder.toString(); @@ -224,10 +224,7 @@ public static void setVersion( if ( propertyName == null ) { packageVersions.put(newPackageName, versionText); } else { - Map versionsForProperty = specificPackageVersions.get(propertyName); - if ( versionsForProperty == null ) { - specificPackageVersions.put( propertyName, (versionsForProperty = new HashMap<>()) ); - } + Map versionsForProperty = specificPackageVersions.computeIfAbsent(propertyName, k -> new HashMap<>()); versionsForProperty.put(newPackageName, versionText); } } @@ -266,7 +263,6 @@ public static > MAP copyPropertiesToMap(Properti * file. * @throws TransformException Thrown if an error occurs processing the file. */ - @SuppressWarnings("resource") public static boolean isFeatureManifest(String manifestPath, File manifestFile) throws TransformException { FileReader manifestReader; try { diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/Transformer.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/Transformer.java index f953079b..8f2fda4c 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/Transformer.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/Transformer.java @@ -47,7 +47,6 @@ import org.eclipse.transformer.action.ContainerChanges; import org.eclipse.transformer.action.SelectionRule; import org.eclipse.transformer.action.SignatureRule; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.ActionSelectorImpl; import org.eclipse.transformer.action.impl.BundleDataImpl; import org.eclipse.transformer.action.impl.ClassActionImpl; @@ -207,8 +206,7 @@ protected ResultCode basicRun() { } Changes lastActiveChanges = getLastActiveChanges(); - if (lastActiveChanges instanceof ContainerChanges) { - ContainerChanges containerChanges = (ContainerChanges) lastActiveChanges; + if (lastActiveChanges instanceof ContainerChanges containerChanges) { int numDuplicated = containerChanges.getAllDuplicated(); int numFailed = containerChanges.getAllFailed(); @@ -458,28 +456,28 @@ protected void processImmediateData( throws IOException, URISyntaxException { for ( ImmediateRuleData nextData : immediateData ) { - switch ( nextData.target ) { + switch ( nextData.target() ) { case RULES_SELECTIONS: - addImmediateSelection(nextData.key, nextData.value); + addImmediateSelection(nextData.key(), nextData.value()); break; case RULES_RENAMES: - addImmediateRename(nextData.key, nextData.value, orphanedFinalVersions); + addImmediateRename(nextData.key(), nextData.value(), orphanedFinalVersions); break; case RULES_VERSIONS: - addImmediateVersion(nextData.key, nextData.value); + addImmediateVersion(nextData.key(), nextData.value()); break; case RULES_BUNDLES: - addImmediateBundleData(nextData.key, nextData.value); + addImmediateBundleData(nextData.key(), nextData.value()); break; case RULES_DIRECT: - addImmediateDirect(nextData.key, nextData.value); + addImmediateDirect(nextData.key(), nextData.value()); break; case RULES_MASTER_TEXT: - addImmediateMasterText(masterTextRef, nextData.key, nextData.value); + addImmediateMasterText(masterTextRef, nextData.key(), nextData.value()); break; default: - getLogger().error(consoleMarker, "Unrecognized immediate data target [ {} ]", nextData.target); + getLogger().error(consoleMarker, "Unrecognized immediate data target [ {} ]", nextData.target()); } } } @@ -1103,7 +1101,7 @@ private boolean outputExists(File outputFile) { // As a separate method to allow re-use. public ActionContext getActionContext() { - return new ActionContextImpl(getLogger(), getSelectionRule(), getSignatureRule()); + return new ActionContext(getLogger(), getSelectionRule(), getSignatureRule()); } public ActionSelector getActionSelector() { diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ActionContext.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ActionContext.java index 62265d42..8646db48 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ActionContext.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ActionContext.java @@ -19,10 +19,13 @@ import org.slf4j.Logger; -public interface ActionContext { - Logger getLogger(); +import static java.util.Objects.requireNonNull; - SelectionRule getSelectionRule(); - - SignatureRule getSignatureRule(); +public record ActionContext(Logger logger, SelectionRule selectionRule, + SignatureRule signatureRule) { + public ActionContext(Logger logger, SelectionRule selectionRule, SignatureRule signatureRule) { + this.logger = requireNonNull(logger); + this.selectionRule = requireNonNull(selectionRule); + this.signatureRule = requireNonNull(signatureRule); + } } diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ByteData.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ByteData.java index 6e891362..256fff2e 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ByteData.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/ByteData.java @@ -48,9 +48,6 @@ public interface ByteData { * data. The settings of the copy buffer (length, limit, and remaining) * start the same as the settings of the buffer of this data, but are * updated independently. - *

- * For a buffer which has its position set to zero, use instead - * {@link #buffer()}. * * @return The buffer associated with the data. */ diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionContextImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionContextImpl.java deleted file mode 100644 index 9ccfe697..00000000 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionContextImpl.java +++ /dev/null @@ -1,52 +0,0 @@ -/******************************************************************************* - * Copyright (c) Contributors to the Eclipse Foundation - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - * - * SPDX-License-Identifier: Apache-2.0 - *******************************************************************************/ -package org.eclipse.transformer.action.impl; - -import static java.util.Objects.requireNonNull; - -import org.eclipse.transformer.action.ActionContext; -import org.eclipse.transformer.action.SelectionRule; -import org.eclipse.transformer.action.SignatureRule; -import org.slf4j.Logger; - -public class ActionContextImpl implements ActionContext { - public ActionContextImpl(Logger logger, SelectionRule selectionRule, SignatureRule signatureRule) { - this.logger = requireNonNull(logger); - this.selectionRule = requireNonNull(selectionRule); - this.signatureRule = requireNonNull(signatureRule); - } - - private final Logger logger; - private final SelectionRule selectionRule; - private final SignatureRule signatureRule; - - @Override - public Logger getLogger() { - return logger; - } - - @Override - public SelectionRule getSelectionRule() { - return selectionRule; - } - - @Override - public SignatureRule getSignatureRule() { - return signatureRule; - } -} diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionImpl.java index b26ec5f1..822be386 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ActionImpl.java @@ -100,21 +100,21 @@ protected ActionContext getContext() { } protected Logger getLogger() { - return getContext().getLogger(); + return getContext().logger(); } // @Override public SelectionRule getResourceSelectionRule() { - return getContext().getSelectionRule(); + return getContext().selectionRule(); } // @Override public SignatureRule getSignatureRule() { - return getContext().getSignatureRule(); + return getContext().signatureRule(); } public Map getPackageRenames() { diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ClassActionImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ClassActionImpl.java index a56ac061..ed33941f 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ClassActionImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ClassActionImpl.java @@ -240,7 +240,7 @@ private String traceDumpLine(StringBuilder builder, ByteBuffer buffer, int width public ClassActionImpl(ActionContext context) { super(context); - List useReplacements = createActiveReplacements(context.getSignatureRule()); + List useReplacements = createActiveReplacements(context.signatureRule()); this.activeReplacements = useReplacements.isEmpty() ? NO_ACTIVE_REPLACEMENTS : useReplacements; } @@ -1174,8 +1174,7 @@ private ElementValueInfo[] transform(ElementValueInfo[] inputElementValues, Stri private Object transformElementValue(Object inputValue, String inputName, String annotationType, String elementName) { - if (inputValue instanceof EnumConst) { - EnumConst enumValue = (EnumConst) inputValue; + if (inputValue instanceof EnumConst enumValue) { String inputType = enumValue.type; String outputType = transformDescriptor(inputType); if (outputType == null) { @@ -1184,8 +1183,7 @@ private Object transformElementValue(Object inputValue, String inputName, String return new EnumConst(outputType, enumValue.name); } - } else if (inputValue instanceof ResultConst) { - ResultConst resultValue = (ResultConst) inputValue; + } else if (inputValue instanceof ResultConst resultValue) { String inputDescriptor = resultValue.descriptor; String outputDescriptor = transformDescriptor(inputDescriptor); if (outputDescriptor == null) { @@ -1194,12 +1192,10 @@ private Object transformElementValue(Object inputValue, String inputName, String return new ResultConst(outputDescriptor); } - } else if (inputValue instanceof AnnotationInfo) { - AnnotationInfo annotationValue = (AnnotationInfo) inputValue; + } else if (inputValue instanceof AnnotationInfo annotationValue) { return transform(annotationValue, AnnotationInfo::new, inputName); - } else if (inputValue instanceof String) { - String stringValue = (String) inputValue; + } else if (inputValue instanceof String stringValue) { String result = transformString(inputName, "AnnotationValue", stringValue); // Replace package version in OSGi Version annotation. if (inputName.endsWith("/package-info.class") @@ -1213,8 +1209,7 @@ private Object transformElementValue(Object inputValue, String inputName, String } } return result; - } else if (inputValue instanceof Object[]) { - Object[] inputElementValues = ((Object[]) inputValue); + } else if (inputValue instanceof Object[] inputElementValues) { Object[] outputElementValues = null; for (int valueNo = 0; valueNo < inputElementValues.length; valueNo++) { @@ -1255,10 +1250,9 @@ private VerificationTypeInfo[] transform(VerificationTypeInfo[] inputVtis) { } private VerificationTypeInfo transform(VerificationTypeInfo vti) { - if (!(vti instanceof ObjectVariableInfo)) { + if (!(vti instanceof ObjectVariableInfo inputOvi)) { return null; } - ObjectVariableInfo inputOvi = (ObjectVariableInfo) vti; String inputType = inputOvi.type; if (inputType == null) { @@ -1287,6 +1281,7 @@ private int transform(MutableConstantPool constants, String inputName) throws Tr int numConstants = constants.size(); for (int constantNo = 1; constantNo < numConstants; constantNo++) { if (useLogger.isTraceEnabled()) { + //noinspection StringConcatenationArgumentToLogCall useLogger .trace(String.format("Constant [ %3s ] [ %16s ] [ %s ]", constantNo, constants.tag(constantNo), constants.entry(constantNo))); diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ContainerActionImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ContainerActionImpl.java index 36567ec1..b87ad3fb 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ContainerActionImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ContainerActionImpl.java @@ -104,7 +104,7 @@ protected void recordAction(Action action, String resourceName) { protected void recordError(Action action, String resourceName, Throwable error) { String actionName = ( (action == null) ? "null" : action.getName() ); - getLogger().error("Resource [ " + resourceName + " ] Action [ " + actionName + " ]: Failed transform", error); + getLogger().error("Resource [ {} ] Action [ {} ]: Failed transform", resourceName, actionName, error); getActiveChanges().recordFailed(action); } diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ManifestActionImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ManifestActionImpl.java index db9d45c1..4ba70a1c 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ManifestActionImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ManifestActionImpl.java @@ -550,10 +550,7 @@ protected boolean firstCharIsSemicolon(String s) { if (Character.isWhitespace(s.charAt(i))) { continue; } - if (s.charAt(i) == ';') { - return true; - } - return false; + return s.charAt(i) == ';'; } return false; } @@ -581,10 +578,7 @@ private boolean isPackageDelimitingComma(String testString, String packageText, int indexOfNextNonWhiteSpaceCharAfterComma = indexOfNextNonWhiteSpaceChar(testString, indexOfComma + 1); char characterAfterComma = testString.charAt(indexOfNextNonWhiteSpaceCharAfterComma); if (Character.isAlphabetic(characterAfterComma)) { - if (!hasEvenNumberOfOccurrencesOfChar(packageText, '\"')) { - return false; - } - return true; + return hasEvenNumberOfOccurrencesOfChar(packageText, '\"'); } return false; diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/SignatureRuleImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/SignatureRuleImpl.java index b49197fc..ddad64ba 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/SignatureRuleImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/SignatureRuleImpl.java @@ -548,7 +548,7 @@ private String replaceTextDirect(String initialValue, String inputName, Map - * See {@replacePackage}. + * See {@link #replacePackage(String)}. * * @param inputName The input name which is to be renamed. * @return The updated name. Null if no change is to be made. diff --git a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ZipActionImpl.java b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ZipActionImpl.java index e90031e7..5b17b972 100644 --- a/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ZipActionImpl.java +++ b/org.eclipse.transformer/src/main/java/org/eclipse/transformer/action/impl/ZipActionImpl.java @@ -346,9 +346,7 @@ private void applyZipStream( ByteData inputData = collect(inputName, zipInputStream, inputLength); ByteData outputData = zipAction.apply(inputData); ZipEntry outputEntry = createEntry(inputEntry, outputName, outputData); - putEntry(zipOutputStream, outputEntry, () -> { - outputData.writeTo(zipOutputStream); - }); + putEntry(zipOutputStream, outputEntry, () -> outputData.writeTo(zipOutputStream)); } else { // For COMPRESSED, we use streaming. // Loading entire archives into memory is to be avoided. @@ -481,9 +479,7 @@ public void writeUnmodified( getLogger().trace("Write unmodified entry [ {} ] bytes [ {} ]", outputName, outputData.length()); ZipEntry outputEntry = copyEntry(inputEntry, outputName); - putEntry(zipOutputStream, outputEntry, () -> { - outputData.writeTo(zipOutputStream); - }); + putEntry(zipOutputStream, outputEntry, () -> outputData.writeTo(zipOutputStream)); } public void writeModified( @@ -494,9 +490,7 @@ public void writeModified( getLogger().trace("Write modified entry [ {} ] bytes [ {} ]", outputName, outputData.length()); ZipEntry outputEntry = createEntry(inputEntry, outputName, outputData); - putEntry(zipOutputStream, outputEntry, () -> { - outputData.writeTo(zipOutputStream); - }); + putEntry(zipOutputStream, outputEntry, () -> outputData.writeTo(zipOutputStream)); } private ZipEntry createEntry(ZipEntry inputEntry, String outputName) { diff --git a/org.eclipse.transformer/src/test/java/transformer/test/ClassActionTest.java b/org.eclipse.transformer/src/test/java/transformer/test/ClassActionTest.java index 09423398..ef8a62d0 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/ClassActionTest.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/ClassActionTest.java @@ -40,7 +40,6 @@ import org.assertj.core.api.recursive.comparison.RecursiveComparisonConfiguration; import org.eclipse.transformer.action.ActionContext; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.ByteDataImpl; import org.eclipse.transformer.action.impl.ClassActionImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; @@ -120,7 +119,7 @@ public void module_transform() throws Exception { renames.put("original.provides.impl", "transformed.provides.impl"); renames.put("original.main", "transformed.main"); - ActionContext context = new ActionContextImpl(logger, + ActionContext context = new ActionContext(logger, new SelectionRuleImpl(logger, Collections.emptyMap(), Collections.emptyMap()), new SignatureRuleImpl(logger, renames, null, null, null, null, null, Collections.emptyMap())); ClassActionImpl classAction = new ClassActionImpl(context); @@ -216,7 +215,7 @@ public void nest_transform() throws Exception { Map renames = new HashMap<>(); renames.put("original.host", "transformed.host"); renames.put("original.member", "transformed.member"); - ActionContext context = new ActionContextImpl(logger, + ActionContext context = new ActionContext(logger, new SelectionRuleImpl(logger, Collections.emptyMap(), Collections.emptyMap()), new SignatureRuleImpl(logger, renames, null, null, null, null, null, Collections.emptyMap())); @@ -260,7 +259,7 @@ public void enclosing_method_transform() throws Exception { renames.put("original.enclosing", "transformed.enclosing"); renames.put("original.param", "transformed.param"); renames.put("original.result", "transformed.result"); - ActionContext context = new ActionContextImpl(logger, + ActionContext context = new ActionContext(logger, new SelectionRuleImpl(logger, Collections.emptyMap(), Collections.emptyMap()), new SignatureRuleImpl(logger, renames, null, null, null, null, null, Collections.emptyMap())); ClassActionImpl classAction = new ClassActionImpl(context); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/RenameActionTest.java b/org.eclipse.transformer/src/test/java/transformer/test/RenameActionTest.java index 3555a07b..fb4a5281 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/RenameActionTest.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/RenameActionTest.java @@ -18,7 +18,6 @@ import aQute.bnd.unmodifiable.Maps; import org.eclipse.transformer.action.ActionContext; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.RenameActionImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; import org.eclipse.transformer.action.impl.SignatureRuleImpl; @@ -48,7 +47,7 @@ public void setUp(TestInfo testInfo) { @Test void relocate_resource() { - ActionContext context = new ActionContextImpl(logger, + ActionContext context = new ActionContext(logger, new SelectionRuleImpl(logger, Collections.emptyMap(), Collections.emptyMap()), new SignatureRuleImpl(logger, Maps.of("com.a.b.*", "com.shaded.a.b"), null, null, null, null, null, Collections.emptyMap())); RenameActionImpl action = new RenameActionImpl(context); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/SelectionTests.java b/org.eclipse.transformer/src/test/java/transformer/test/SelectionTests.java index e32e9cb1..c6c19948 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/SelectionTests.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/SelectionTests.java @@ -35,17 +35,16 @@ class SelectionTests { @Test void selections() throws Exception { UTF8Properties properties = new UTF8Properties(); - properties.load("# comment\n" + - "*=UTF-8\n" + - "*.properties=ISO-8859-1\n" + - "*Abstract*=US-ASCII\n" + - "wide/*=UTF-16\n" + - "! comment\n" + - "*.proto=!", null, null); + properties.load(""" + # comment + *=UTF-8 + *.properties=ISO-8859-1 + *Abstract*=US-ASCII + wide/*=UTF-16 + ! comment + *.proto=!""", null, null); Map selectionProperties = new HashMap<>(); - properties.forEach((k,v) -> { - selectionProperties.put(k.toString(), v.toString()); - }); + properties.forEach((k,v) -> selectionProperties.put(k.toString(), v.toString())); Map includes = new HashMap<>(); Map excludes = new HashMap<>(); TransformProperties.addSelections(includes, excludes, selectionProperties); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformClass.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformClass.java index e7aaae33..c9d0a11c 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformClass.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformClass.java @@ -44,7 +44,6 @@ import org.eclipse.transformer.action.ActionContext; import org.eclipse.transformer.action.ActionType; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.ClassActionImpl; import org.eclipse.transformer.action.impl.ClassChangesImpl; import org.eclipse.transformer.action.impl.ServiceLoaderConfigActionImpl; @@ -246,9 +245,7 @@ public Map getToJakartaRenames() { public void displayJakartaPackageRenames() { System.out.println("Package Renames [ javax -> jakarta ]"); - getToJakartaRenames().forEach((key, value) -> { - System.out.println(" [ " + key + " ] --> [ " + value + " ]"); - }); + getToJakartaRenames().forEach((key, value) -> System.out.println(" [ " + key + " ] --> [ " + value + " ]")); } // @@ -279,9 +276,7 @@ public Map toJakartaDirectStrings() { public void displayJakartaGlobalDirectStrings() { System.out.println("Global Direct Strings [ javax -> jakarta ]"); - toJakartaDirectStrings().forEach((key, value) -> { - System.out.println(" [ " + key + " ] --> [ " + value + " ]"); - }); + toJakartaDirectStrings().forEach((key, value) -> System.out.println(" [ " + key + " ] --> [ " + value + " ]")); } protected static final String PER_CLASS_OVERRIDE_PACKAGE_NAME = "transformer.test.data2"; @@ -303,9 +298,7 @@ public void displayJakartaPerClassDirectStrings() { System.out.println("Per Class Direct Strings [ javax -> jakarta ]"); toJakartaPerClassDirectStrings().forEach((className, directStrings) -> { System.out.println(" [ " + className + " ]:"); - directStrings.forEach((key, value) -> { - System.out.println(" [ " + key + " ] --> [ " + value + " ]"); - }); + directStrings.forEach((key, value) -> System.out.println(" [ " + key + " ] --> [ " + value + " ]")); }); } @@ -341,7 +334,7 @@ public ZipActionImpl getJavaxToJakartaJarAction() { if (toJakartaJarAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getIncludes(), getExcludes()), createSignatureRule(useLogger, getToJakartaRenames(), null, null, null, Collections.emptyMap())); @@ -359,7 +352,7 @@ public ZipActionImpl getJakartaToJavaxJarAction() { Map toJavaxRenames = TransformProperties.invert(getToJakartaRenames()); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getIncludes(), getExcludes()), createSignatureRule(useLogger, toJavaxRenames, null, null, null, Collections.emptyMap())); @@ -375,7 +368,7 @@ public ZipActionImpl getJavaxToJakartaJarAction_DirectOverride() { if (toJakartaJarAction_DirectOverride == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getOverrideIncludes(), getExcludes()), createSignatureRule(useLogger, getToJakartaRenames(), null, null, toJakartaDirectStrings(), null)); @@ -391,7 +384,7 @@ public ZipActionImpl getJavaxToJakartaJarAction_PerClassDirectOverride() { if (toJakartaJarAction_PerClassDirectOverride == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getOverrideIncludes(), getExcludes()), createSignatureRule(useLogger, getToJakartaRenames(), null, null, toJakartaDirectStrings(), toJakartaPerClassDirectStrings())); @@ -408,7 +401,7 @@ public ZipActionImpl getJavaxToJakartaJarAction_PackageRenamesOnly() { if (toJakartaJarAction_PackageRenamesOnly == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getOverrideIncludes(), getExcludes()), createSignatureRule(useLogger, getToJakartaRenames(), null, null, null, null)); @@ -521,7 +514,7 @@ public static Map loadRenames(String resourceRef) throws IOExcep public ClassActionImpl createToJakartaClassAction() { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, Collections.emptyMap(), Collections.emptyMap()), createSignatureRule(useLogger, getToJakartaRenames(), null, null, null, Collections.emptyMap())); @@ -584,7 +577,7 @@ protected void display(String msg, Object... parms) { if (parms.length == 0) { System.out.println(msg); } else { - System.out.println(String.format(msg, parms)); + System.out.printf((msg) + "%n", parms); } } @@ -822,7 +815,7 @@ public static final Map getDirectStrings() { public ClassActionImpl createDirectClassAction() { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, Collections.emptyMap(), Collections.emptyMap()), createSignatureRule( useLogger, Collections.emptyMap(), null, null, getDirectStrings(), Collections.emptyMap())); @@ -832,7 +825,7 @@ public ClassActionImpl createDirectClassAction() { public ClassActionImpl createPerClassConstantClassAction() { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, Collections.emptyMap(), Collections.emptyMap()), createSignatureRule(useLogger, Collections.emptyMap(), null, null, null, PER_CLASS_CONSTANT_MASTER)); @@ -929,26 +922,8 @@ public void testPerClassConstant() throws TransformException, IOException { public static final boolean IS_EXACT = false; - public static class ClassRelocation { - public final String inputPath; - public final String inputName; - - public final String outputName; - public final String outputPath; - - public final boolean isApproximate; - - public ClassRelocation(String inputPath, String inputName, String outputName, String outputPath, - boolean isApproximate) { - - this.inputPath = inputPath; - this.inputName = inputName; - - this.outputName = outputName; - this.outputPath = outputPath; - - this.isApproximate = isApproximate; - } + public record ClassRelocation(String inputPath, String inputName, String outputName, String outputPath, + boolean isApproximate) { } public static ClassRelocation[] RELOCATION_CASES = new ClassRelocation[] { @@ -978,13 +953,16 @@ public ClassRelocation(String inputPath, String inputName, String outputName, St public void testClassRelocation() { ClassActionImpl classAction = createDirectClassAction(); for (ClassRelocation relocationCase : RELOCATION_CASES) { - String outputPath = classAction.relocateClass(relocationCase.inputPath, - relocationCase.inputName, relocationCase.outputName); + String outputPath = classAction.relocateClass(relocationCase.inputPath(), + relocationCase.inputName(), relocationCase.outputName()); List capturedEvents = consumeCapturedEvents(); - System.out.printf("Relocation [ %s ] as [ %s ]\n" + " to [ %s ] as [ %s ]\n", - relocationCase.inputPath, relocationCase.inputName, relocationCase.outputName, outputPath); + System.out.printf(""" + Relocation [ %s ] as [ %s ] + to [ %s ] as [ %s ] + """, + relocationCase.inputPath(), relocationCase.inputName(), relocationCase.outputName(), outputPath); boolean capturedApproximate = false; for (CaptureLoggerImpl.LogEvent event : capturedEvents) { @@ -994,9 +972,9 @@ public void testClassRelocation() { } } - Assertions.assertEquals(relocationCase.outputPath, outputPath, "Incorrect output path"); + Assertions.assertEquals(relocationCase.outputPath(), outputPath, "Incorrect output path"); - Assertions.assertEquals(capturedApproximate, relocationCase.isApproximate, "Approximate error not logged"); + Assertions.assertEquals(capturedApproximate, relocationCase.isApproximate(), "Approximate error not logged"); } } @@ -1197,7 +1175,7 @@ public static Map getStandardRenames() throws IOException { public ClassActionImpl createStandardClassAction() throws IOException { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, Collections.emptyMap(), Collections.emptyMap()), createSignatureRule(useLogger, getStandardRenames(), null, null, null, Collections.emptyMap())); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformManifest.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformManifest.java index 5df5c906..9d15b205 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformManifest.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformManifest.java @@ -30,7 +30,6 @@ import org.eclipse.transformer.action.ActionType; import org.eclipse.transformer.action.BundleData; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.BundleDataImpl; import org.eclipse.transformer.action.impl.ManifestActionImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; @@ -197,7 +196,7 @@ public ManifestActionImpl getJakartaManifestAction() { if (jakartaManifestAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), null, getBundleUpdates(), null, getDirectStrings(), Collections.emptyMap())); @@ -213,7 +212,7 @@ public ManifestActionImpl getJakartaFeatureAction() { if (jakartaFeatureAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), null, null, null, null, Collections.emptyMap())); @@ -232,7 +231,7 @@ public ManifestActionImpl getJakartaManifestActionTx() { if (jakartaManifestActionTx == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), null, getBundleUpdatesTx(), null, getDirectStrings(), Collections.emptyMap())); @@ -249,7 +248,7 @@ public ManifestActionImpl getSpecificJakartaManifestAction() { if (specificJakartaManifestAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), getSpecificPackageVersions(), getBundleUpdatesTx(), null, getDirectStrings(), Collections.emptyMap())); @@ -262,55 +261,37 @@ public ManifestActionImpl getSpecificJakartaManifestAction() { // - protected static final class Occurrences { - public final String initialTag; - public final int initialTagInitialCount; - public final int initialTagFinalCount; - - public final String finalTag; - public final int finalTagInitialCount; - public final int finalTagFinalCount; - - public Occurrences(String initialTag, int initialTagInitialCount, int initialTagFinalCount, String finalTag, - int finalTagInitialCount, int finalTagFinalCount) { - - this.initialTag = initialTag; - this.initialTagInitialCount = initialTagInitialCount; - this.initialTagFinalCount = initialTagFinalCount; - - this.finalTag = finalTag; - this.finalTagInitialCount = finalTagInitialCount; - this.finalTagFinalCount = finalTagFinalCount; - } + public record Occurrences(String initialTag, int initialTagInitialCount, int initialTagFinalCount, + String finalTag, int finalTagInitialCount, int finalTagFinalCount) { public void verifyInitial(List lines) { - int actualInitialTagInitial = TestUtils.occurrences(lines, initialTag); - System.out.println("Tag [ " + initialTag + " ]" + - " Expected [ " + initialTagInitialCount + " ]" + - " Actual [ " + actualInitialTagInitial + " ]"); - Assertions.assertEquals(initialTagInitialCount, actualInitialTagInitial, initialTag); - - int actualFinalTagInitial = TestUtils.occurrences(lines, finalTag); - System.out.println("Tag [ " + finalTag + " ]" + - " Expected [ " + finalTagInitialCount + " ]" + - " Actual [ " + actualFinalTagInitial + " ]"); - Assertions.assertEquals(finalTagInitialCount, actualFinalTagInitial, initialTag); - } + int actualInitialTagInitial = TestUtils.occurrences(lines, initialTag()); + System.out.println("Tag [ " + initialTag() + " ]" + + " Expected [ " + initialTagInitialCount() + " ]" + + " Actual [ " + actualInitialTagInitial + " ]"); + Assertions.assertEquals(initialTagInitialCount(), actualInitialTagInitial, initialTag()); + + int actualFinalTagInitial = TestUtils.occurrences(lines, finalTag()); + System.out.println("Tag [ " + finalTag() + " ]" + + " Expected [ " + finalTagInitialCount() + " ]" + + " Actual [ " + actualFinalTagInitial + " ]"); + Assertions.assertEquals(finalTagInitialCount(), actualFinalTagInitial, initialTag()); + } - public void verifyFinal(List lines) { - int actualInitialTagFinal = TestUtils.occurrences(lines, initialTag); - System.out.println("Tag [ " + initialTag + " ]" + - " Expected [ " + initialTagFinalCount + " ]" + - " Actual [ " + actualInitialTagFinal + " ]"); - Assertions.assertEquals(initialTagFinalCount, actualInitialTagFinal, initialTag); - - int actualFinalTagFinal = TestUtils.occurrences(lines, finalTag); - System.out.println("Tag [ " + finalTag + " ]" + - " Expected [ " + finalTagFinalCount + " ]" + - " Actual [ " + actualFinalTagFinal + " ]"); - Assertions.assertEquals(finalTagFinalCount, actualFinalTagFinal, initialTag); + public void verifyFinal(List lines) { + int actualInitialTagFinal = TestUtils.occurrences(lines, initialTag()); + System.out.println("Tag [ " + initialTag() + " ]" + + " Expected [ " + initialTagFinalCount() + " ]" + + " Actual [ " + actualInitialTagFinal + " ]"); + Assertions.assertEquals(initialTagFinalCount(), actualInitialTagFinal, initialTag()); + + int actualFinalTagFinal = TestUtils.occurrences(lines, finalTag()); + System.out.println("Tag [ " + finalTag() + " ]" + + " Expected [ " + finalTagFinalCount() + " ]" + + " Actual [ " + actualFinalTagFinal + " ]"); + Assertions.assertEquals(finalTagFinalCount(), actualFinalTagFinal, initialTag()); + } } - } // @@ -614,7 +595,7 @@ public void testTransformManifest_Transaction() throws TransformException, IOExc /** * Subclass which allows us to call protected methods of ManifestActionImpl */ - class ManifestActionImpl_Test extends ManifestActionImpl { + protected static class ManifestActionImpl_Test extends ManifestActionImpl { public ManifestActionImpl_Test(ActionContext context) { super(context, ActionType.MANIFEST); } @@ -642,7 +623,7 @@ protected ManifestActionImpl_Test getManifestAction() { if (manifestAction_test == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), null, null, null, null, Collections.emptyMap())); manifestAction_test = new ManifestActionImpl_Test(context); @@ -657,7 +638,7 @@ protected ManifestActionImpl_Test getSpecificManifestAction() { if (specificManifestAction_test == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, getPackageRenames(), getPackageVersions(), getSpecificPackageVersions(), diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformPropertiesFile.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformPropertiesFile.java index 4da81a71..f13730f1 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformPropertiesFile.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformPropertiesFile.java @@ -21,7 +21,6 @@ import org.eclipse.transformer.TransformException; import org.eclipse.transformer.action.ActionContext; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.PropertiesActionImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; import org.eclipse.transformer.action.impl.SignatureRuleImpl; @@ -105,7 +104,7 @@ public PropertiesActionImpl getJakartaPropertiesAction() { if (jakartaPropertiesAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getIncludes(), getExcludes()), createSignatureRule(useLogger, getPackageRenames(), getDirectStrings())); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformServiceConfig.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformServiceConfig.java index 565e6d1d..36614a4a 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformServiceConfig.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformServiceConfig.java @@ -29,7 +29,6 @@ import org.eclipse.transformer.action.ActionType; import org.eclipse.transformer.action.BundleData; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.PropertiesActionImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; import org.eclipse.transformer.action.impl.ServiceLoaderConfigActionImpl; @@ -159,7 +158,7 @@ public ServiceLoaderConfigActionImpl getJakartaServiceAction() { if (jakartaServiceAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getIncludes(), getExcludes()), createSignatureRule(useLogger, getPackageRenames(), null, null, null)); @@ -174,7 +173,7 @@ public ServiceLoaderConfigActionImpl getJavaxServiceAction() { Map invertedRenames = TransformProperties.invert(getPackageRenames()); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, getIncludes(), getExcludes()), createSignatureRule(useLogger, invertedRenames, null, null, null)); @@ -189,7 +188,7 @@ public ZipActionImpl getJarJavaxServiceAction() { Map invertedRenames = TransformProperties.invert(getPackageRenames()); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, createSelectionRule(useLogger, Collections.emptyMap(), getExcludes()), createSignatureRule(useLogger, invertedRenames, null, null, null)); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformXML.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformXML.java index 4a8fc8cf..7dbfa6d5 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformXML.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformXML.java @@ -22,7 +22,6 @@ import org.eclipse.transformer.TransformException; import org.eclipse.transformer.action.ActionContext; import org.eclipse.transformer.action.ByteData; -import org.eclipse.transformer.action.impl.ActionContextImpl; import org.eclipse.transformer.action.impl.SelectionRuleImpl; import org.eclipse.transformer.action.impl.SignatureRuleImpl; import org.eclipse.transformer.action.impl.TextActionImpl; @@ -102,7 +101,7 @@ public TextActionImpl getTextAction() { if (textAction == null) { CaptureLoggerImpl useLogger = getCaptureLogger(); - ActionContext context = new ActionContextImpl(useLogger, + ActionContext context = new ActionContext(useLogger, new SelectionRuleImpl(useLogger, getIncludes(), getExcludes()), new SignatureRuleImpl(useLogger, null, null, null, null, getMasterXmlUpdates(), null, Collections.emptyMap())); @@ -114,14 +113,7 @@ public TextActionImpl getTextAction() { // - protected static final class Occurrences { - public final String tag; - public final int count; - - public Occurrences(String tag, int count) { - this.tag = tag; - this.count = count; - } + public record Occurrences(String tag, int count) { } public static final Occurrences[] UT_INITIAL_OCCURRENCES = { @@ -186,8 +178,8 @@ public void verify(String resourceRef, String caseTag, Occurrences[] occurrences System.out.println("Verify [ " + resourceRef + " ] [ " + caseTag + " ] ..."); for (Occurrences occurrence : occurrences) { - String occurrenceTag = occurrence.tag; - int expected = occurrence.count; + String occurrenceTag = occurrence.tag(); + int expected = occurrence.count(); int actual = TestUtils.occurrences(lines, occurrenceTag); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerImmediateRenames.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerImmediateRenames.java index 3509c525..cf49b98c 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerImmediateRenames.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerImmediateRenames.java @@ -78,14 +78,14 @@ void testMultiRenames() throws Exception { TestUtils.verifyPackageVersions("initial package versions", inputFileName, initialPackageVersions, TARGET_ATTRIBUTE_NAME); Map> options = new HashMap<>(); - options.put(AppOption.OVERWRITE, Arrays.asList("true")); - options.put(AppOption.LOG_LEVEL, Arrays.asList("debug")); + options.put(AppOption.OVERWRITE, List.of("true")); + options.put(AppOption.LOG_LEVEL, List.of("debug")); options.put(AppOption.RULES_IMMEDIATE_DATA, Arrays.asList("tr", "javax.package1", "jakarta.package11", // "tr", "javax.package2", "jakarta.package22", // "tv", "jakarta.package11", "1.1.1", // "tv", "jakarta.package22", "2.1.1")); - options.put(AppOption.RULES_RENAMES, Arrays.asList(inputDir + '/' + "tier0.renames.properties")); - options.put(AppOption.RULES_VERSIONS, Arrays.asList(inputDir + '/' + "tier0.versions.properties")); + options.put(AppOption.RULES_RENAMES, List.of(inputDir + '/' + "tier0.renames.properties")); + options.put(AppOption.RULES_VERSIONS, List.of(inputDir + '/' + "tier0.versions.properties")); runTransformer(inputFileName, outputFileName, options, getLogFragments()); TestUtils.verifyPackageVersions("final package versions", outputFileName, finalPackageVersions, TARGET_ATTRIBUTE_NAME); @@ -106,14 +106,14 @@ public List getLogFragments() { public static final Map finalPackageVersions; static { - initialPackageVersions = new HashMap(8); + initialPackageVersions = new HashMap<>(8); initialPackageVersions.put("javax.package0", "0.0.0"); initialPackageVersions.put("javax.package1", "1.0.0"); initialPackageVersions.put("javax.package2", "2.0.0"); initialPackageVersions.put("javax.package3", "3.0.0"); - finalPackageVersions = new HashMap(8); + finalPackageVersions = new HashMap<>(8); finalPackageVersions.put("jakarta.package0", "0.0.1"); finalPackageVersions.put("jakarta.package11", "1.1.1"); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerJava.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerJava.java index f4902273..f236eba2 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerJava.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerJava.java @@ -18,7 +18,6 @@ import java.io.File; import java.util.ArrayList; -import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -118,9 +117,9 @@ public static void setUp() throws Exception { System.out.println("Renames [ " + renamesPath + " ]"); options = new HashMap<>(); - options.put(AppOption.OVERWRITE, Arrays.asList("true")); - options.put(AppOption.LOG_LEVEL, Arrays.asList("TRACE")); - options.put(AppOption.RULES_RENAMES, Arrays.asList(renamesPath)); + options.put(AppOption.OVERWRITE, List.of("true")); + options.put(AppOption.LOG_LEVEL, List.of("TRACE")); + options.put(AppOption.RULES_RENAMES, List.of(renamesPath)); System.out.println("Overwrite is enabled"); System.out.println("Logging is set to debug"); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiRenames.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiRenames.java index 14f95254..6b6960a8 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiRenames.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiRenames.java @@ -96,8 +96,8 @@ void testMultiRenames() throws Exception { TestUtils.verifyPackageVersions("initial package versions", inputFileName, initialPackageVersions, TARGET_ATTRIBUTE_NAME); Map> options = new HashMap<>(); - options.put(AppOption.OVERWRITE, Arrays.asList("true")); - options.put(AppOption.LOG_LEVEL, Arrays.asList("debug")); + options.put(AppOption.OVERWRITE, List.of("true")); + options.put(AppOption.LOG_LEVEL, List.of("debug")); options.put(AppOption.RULES_RENAMES, Arrays.asList(inputDir + '/' + "tier0.renames.properties", // inputDir + '/' + "tier1.renames.properties", // inputDir + '/' + "tier2.renames.properties")); @@ -124,7 +124,7 @@ public List getLogFragments() { public static final Map finalPackageVersions; static { - initialPackageVersions = new HashMap(8); + initialPackageVersions = new HashMap<>(8); initialPackageVersions.put("javax.package0", "0.0.0"); initialPackageVersions.put("javax.package1", "1.0.0"); @@ -135,7 +135,7 @@ public List getLogFragments() { initialPackageVersions.put("javax.package6", "6.0.0"); initialPackageVersions.put("javax.package7", "7.0.0"); - finalPackageVersions = new HashMap(8); + finalPackageVersions = new HashMap<>(8); finalPackageVersions.put("jakarta.package0", "0.0.1"); finalPackageVersions.put("jakarta.package11", "1.1.1"); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiText.java b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiText.java index c07f56ff..c3299d45 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiText.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestTransformerMultiText.java @@ -75,28 +75,21 @@ public String getDynamicContentDir() { // Rules data ... - public static class TextRulesData { - public final String fileName; - public final String[] assignments; - - public TextRulesData(String fileName, String... assignments) { - this.fileName = fileName; - this.assignments = assignments; - } + public record TextRulesData(String fileName, String... assignments) { public void write(String propertiesDir) throws IOException { - try ( OutputStream outputStream = new FileOutputStream(propertiesDir + '/' + fileName, false) ) { // truncate - OutputStreamWriter outputWriter = new OutputStreamWriter(outputStream); + try (OutputStream outputStream = new FileOutputStream(propertiesDir + '/' + fileName(), false)) { // truncate + OutputStreamWriter outputWriter = new OutputStreamWriter(outputStream); - for ( String assignment : assignments ) { - outputWriter.write(assignment); - outputWriter.write('\n'); - } + for (String assignment : assignments()) { + outputWriter.write(assignment); + outputWriter.write('\n'); + } - outputWriter.flush(); + outputWriter.flush(); + } } } - } public static final String TIER0_MASTER_PROPERTIES = "tier0.master.properties"; public static final String TIER1_MASTER_PROPERTIES = "tier1.master.properties"; @@ -155,7 +148,7 @@ protected static String getInputName(int fileNo, int extNo) { public static final Map OUTPUT_TEXT_MAP; static { - Map outputMap = new HashMap(); + Map outputMap = new HashMap<>(); outputMap.put(".ext0", "The slow brown fox jumps over the happy dog."); outputMap.put(".ext3", INPUT_TEXT); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/TestUtils.java b/org.eclipse.transformer/src/test/java/transformer/test/TestUtils.java index fb35d56f..0caaa6a7 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/TestUtils.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/TestUtils.java @@ -184,14 +184,14 @@ public static List manifestCollapse(List inputManifestLines) { outputBuilder.append(inputLine.charAt(charNo)); } } else { - if (outputBuilder.length() > 0) { + if (!outputBuilder.isEmpty()) { outputManifestLines.add(outputBuilder.toString()); outputBuilder.setLength(0); } outputBuilder.append(inputLine); } } - if (outputBuilder.length() > 0) { + if (!outputBuilder.isEmpty()) { outputManifestLines.add(outputBuilder.toString()); outputBuilder.setLength(0); } @@ -224,7 +224,7 @@ public static Map loadPackageVersions( manifest.read(manifestStream); } - Map packageData = new HashMap(); + Map packageData = new HashMap<>(); String targetAttribute = manifest.getMainAttributes().getValue(attributeName); System.out.println(description + " [ " + manifestPath + " ]:"); @@ -263,7 +263,7 @@ public static void verifyPackageVersions( } public static List verifyPackageVersions(Map actual, Map expected) { - List errors = new ArrayList(); + List errors = new ArrayList<>(); for ( Map.Entry actualEntry : actual.entrySet() ) { String actualName = actualEntry.getKey(); @@ -332,7 +332,7 @@ public static void verifyLog(String description, List expectedFragments, */ public static List verifyLog(List expectedFragments, Collection logEvents) throws IOException { - List errors = new ArrayList(); + List errors = new ArrayList<>(); int expectedMatches = expectedFragments.size(); boolean[] matches = new boolean[expectedMatches]; @@ -413,7 +413,7 @@ public static List verifyOutputFiles( Map outputMap) throws IOException { - List errors = new ArrayList(); + List errors = new ArrayList<>(); for ( int fileNo = 0; fileNo < numFiles; fileNo++ ) { for ( int extNo = 0; extNo < numExts; extNo++ ) { @@ -488,7 +488,7 @@ public ErrorAccumulator(String name, int maxCount) { this.capacity = maxCount; this.size = 0; - this.errors = new ArrayList(maxCount); + this.errors = new ArrayList<>(maxCount); } /** @@ -556,14 +556,7 @@ public static ErrorAccumulator newErrors(String name) { // - public static class InputMapping { - public final File inputFile; - public final String entryName; - - public InputMapping(File inputFile, String entryName) { - this.inputFile = inputFile; - this.entryName = entryName; - } + public record InputMapping(File inputFile, String entryName) { } public static void zip(File sourceDir, File zipFile) throws IOException { @@ -617,13 +610,13 @@ public static void zip(File sourceDir, File zipFile, List inputMap if (inputMappings != null) { inputMappings.forEach(inputMapping -> { System.out.println( - "Zip entry [ " + inputMapping.inputFile.getPath() + " ] as [ " + inputMapping.entryName + " ]"); + "Zip entry [ " + inputMapping.inputFile().getPath() + " ] as [ " + inputMapping.entryName() + " ]"); - ZipEntry zipEntry = new ZipEntry(inputMapping.entryName); + ZipEntry zipEntry = new ZipEntry(inputMapping.entryName()); try { zip.putNextEntry(zipEntry); try { - IO.copy(inputMapping.inputFile, zip); + IO.copy(inputMapping.inputFile(), zip); } finally { zip.closeEntry(); } @@ -838,11 +831,7 @@ public static boolean compareDirectories( zipDirectories = listZipDirectories(zipFile); } catch ( IOException e ) { e.printStackTrace(); - if ( !errors.add("IOException listing actual [ " + zipPath + " ]") ) { - return false; - } else { - return true; - } + return errors.add("IOException listing actual [ " + zipPath + " ]"); } if ( (allowMissing != null) && !allowMissing.isEmpty() ) { @@ -857,11 +846,7 @@ public static boolean compareDirectories( expectedDirectories = listDirectories(expectedParent); } catch ( IOException e ) { e.printStackTrace(); - if ( !errors.add("IOException listing expected [ " + expectedPath + " ]") ) { - return false; - } else { - return true; - } + return errors.add("IOException listing expected [ " + expectedPath + " ]"); } expectedDirectories = convertSlashes(expectedDirectories); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/util/BiDiMapImpl.java b/org.eclipse.transformer/src/test/java/transformer/test/util/BiDiMapImpl.java index 4f2860e5..b80d4da4 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/util/BiDiMapImpl.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/util/BiDiMapImpl.java @@ -131,9 +131,9 @@ public boolean record(Holder holder, Held held) { boolean addedHolderToHeld = recordHeldToHolder(holder, held); if (addedHeldToHolder != addedHolderToHeld) { - System.out.println(String.format( - "[ %s ] Holder [ %s ] Held [ %s ] Added to holder [ %s ] Added to held [ %s ]", getHashText(), holder, - held, Boolean.valueOf(addedHeldToHolder), Boolean.valueOf(addedHolderToHeld))); + System.out.printf( + "[ %s ] Holder [ %s ] Held [ %s ] Added to holder [ %s ] Added to held [ %s ]%n", getHashText(), holder, + held, Boolean.valueOf(addedHeldToHolder), Boolean.valueOf(addedHolderToHeld)); } return addedHeldToHolder; @@ -150,20 +150,12 @@ protected boolean recordHeldToHolder(Holder holder, Held held) { } protected Set recordHolder(Holder holder) { - Set heldBy = holderToHeldMap.get(holder); - if (heldBy == null) { - heldBy = new HashSet<>(); - holderToHeldMap.put(holder, heldBy); - } + Set heldBy = holderToHeldMap.computeIfAbsent(holder, k -> new HashSet<>()); return heldBy; } protected Set recordHeld(Held held) { - Set holderOf = heldToHoldersMap.get(held); - if (holderOf == null) { - holderOf = new HashSet<>(); - heldToHoldersMap.put(held, holderOf); - } + Set holderOf = heldToHoldersMap.computeIfAbsent(held, k -> new HashSet<>()); return holderOf; } diff --git a/org.eclipse.transformer/src/test/java/transformer/test/util/CaptureLoggerImpl.java b/org.eclipse.transformer/src/test/java/transformer/test/util/CaptureLoggerImpl.java index 591b2bcd..e278b1a5 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/util/CaptureLoggerImpl.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/util/CaptureLoggerImpl.java @@ -47,20 +47,13 @@ public CaptureLoggerImpl(Logger baseLogger, boolean captureInactive) { public boolean isLoggable(Level level) { Logger useLogger = getBaseLogger(); - switch (level) { - case ERROR : - return useLogger.isErrorEnabled(); - case WARN : - return useLogger.isWarnEnabled(); - case INFO : - return useLogger.isInfoEnabled(); - case DEBUG : - return useLogger.isDebugEnabled(); - case TRACE : - return useLogger.isTraceEnabled(); - default : - throw new IllegalArgumentException("Unknown level [ " + level + " ]"); - } + return switch (level) { + case ERROR -> useLogger.isErrorEnabled(); + case WARN -> useLogger.isWarnEnabled(); + case INFO -> useLogger.isInfoEnabled(); + case DEBUG -> useLogger.isDebugEnabled(); + case TRACE -> useLogger.isTraceEnabled(); + }; } public Logger getBaseLogger() { diff --git a/org.eclipse.transformer/src/test/java/transformer/test/util/ClassData.java b/org.eclipse.transformer/src/test/java/transformer/test/util/ClassData.java index d4f2b624..831c9859 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/util/ClassData.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/util/ClassData.java @@ -17,6 +17,7 @@ import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Modifier; +import java.util.Arrays; import java.util.Collections; import java.util.HashSet; import java.util.Set; @@ -242,7 +243,7 @@ public void log(PrintWriter writer) { writer.println(logPrefix + "Class name: " + className); writer.println(logPrefix + "Superclass name: " + superclassName); - writer.println(logPrefix + "Interface names: " + interfaceNames); + writer.println(logPrefix + "Interface names: " + Arrays.toString(interfaceNames)); if (classAnnotationNames.isEmpty()) { writer.println(logPrefix + "Class annotations: ** EMPTY **"); diff --git a/org.eclipse.transformer/src/test/java/transformer/test/util/SetDeltaImpl.java b/org.eclipse.transformer/src/test/java/transformer/test/util/SetDeltaImpl.java index a63f0cae..e01b26ab 100644 --- a/org.eclipse.transformer/src/test/java/transformer/test/util/SetDeltaImpl.java +++ b/org.eclipse.transformer/src/test/java/transformer/test/util/SetDeltaImpl.java @@ -77,7 +77,7 @@ public String getHashText() { // protected final Set still_i; public Set getAdded() { - return ((added_f == null) ? null : added_f); + return added_f; } public boolean isNullAdded() { @@ -85,7 +85,7 @@ public boolean isNullAdded() { } public Set getRemoved() { - return ((removed_i == null) ? null : removed_i); + return removed_i; } public boolean isNullRemoved() { @@ -93,7 +93,7 @@ public boolean isNullRemoved() { } public Set getStill() { - return ((still_f == null) ? null : still_f); + return still_f; } public boolean isNullStill() { From 3ce649abfa637f1e67e38a7d92d015699ed073aa Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Tue, 20 Aug 2024 18:18:53 -0400 Subject: [PATCH 6/6] Prepare for 1.0 release! Signed-off-by: BJ Hargrave --- org.eclipse.transformer.parent/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/org.eclipse.transformer.parent/pom.xml b/org.eclipse.transformer.parent/pom.xml index e98edd08..1c3418e8 100644 --- a/org.eclipse.transformer.parent/pom.xml +++ b/org.eclipse.transformer.parent/pom.xml @@ -22,7 +22,7 @@ ${revision} - 0.6.0-SNAPSHOT + 1.0.0-SNAPSHOT UTF-8 UTF-8 17