HHH-17047 - Follow up tasks for Gradle 8.2 upgrade

- toolchains
- lazy Task creation
- documentation (documentation/ and release/) tasks
This commit is contained in:
Steve Ebersole 2023-08-14 12:43:22 -05:00 committed by Christian Beikov
parent 1c449cc2cb
commit a730de8d24
1 changed files with 54 additions and 57 deletions

View File

@ -8,26 +8,22 @@ package org.hibernate.orm.toolchains;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import javax.inject.Inject; import javax.inject.Inject;
import org.gradle.api.Action; import org.gradle.api.Action;
import org.gradle.api.JavaVersion;
import org.gradle.api.Plugin; import org.gradle.api.Plugin;
import org.gradle.api.Project; import org.gradle.api.Project;
import org.gradle.api.Task; import org.gradle.api.Task;
import org.gradle.api.plugins.JavaPluginExtension; import org.gradle.api.plugins.JavaPluginExtension;
import org.gradle.api.tasks.SourceSet; import org.gradle.api.tasks.SourceSet;
import org.gradle.api.tasks.SourceSetContainer; import org.gradle.api.tasks.SourceSetContainer;
import org.gradle.api.tasks.compile.CompileOptions;
import org.gradle.api.tasks.compile.JavaCompile; import org.gradle.api.tasks.compile.JavaCompile;
import org.gradle.api.tasks.javadoc.Javadoc; import org.gradle.api.tasks.javadoc.Javadoc;
import org.gradle.jvm.toolchain.JavaLanguageVersion; import org.gradle.jvm.toolchain.JavaLanguageVersion;
import org.gradle.jvm.toolchain.JavaToolchainService; import org.gradle.jvm.toolchain.JavaToolchainService;
import org.gradle.jvm.toolchain.JavaToolchainSpec;
import static java.util.Arrays.asList;
/** /**
* @author Steve Ebersole * @author Steve Ebersole
@ -53,51 +49,68 @@ public class JavaModulePlugin implements Plugin<Project> {
final SourceSet testSourceSet = sourceSets.getByName( SourceSet.TEST_SOURCE_SET_NAME ); final SourceSet testSourceSet = sourceSets.getByName( SourceSet.TEST_SOURCE_SET_NAME );
final JavaCompile mainCompileTask = (JavaCompile) project.getTasks().getByName( mainSourceSet.getCompileJavaTaskName() ); final JavaCompile mainCompileTask = (JavaCompile) project.getTasks().getByName( mainSourceSet.getCompileJavaTaskName() );
mainCompileTask.setSourceCompatibility( jdkVersionsConfig.getMainCompileVersion().toString() );
mainCompileTask.setTargetCompatibility( jdkVersionsConfig.getMainCompileVersion().toString() );
final JavaCompile testCompileTask = (JavaCompile) project.getTasks().getByName( testSourceSet.getCompileJavaTaskName() ); final JavaCompile testCompileTask = (JavaCompile) project.getTasks().getByName( testSourceSet.getCompileJavaTaskName() );
testCompileTask.setSourceCompatibility( jdkVersionsConfig.getTestCompileVersion().toString() );
testCompileTask.setTargetCompatibility( jdkVersionsConfig.getTestCompileVersion().toString() );
if ( jdkVersionsConfig.isExplicit() ) { if ( !jdkVersionsConfig.isExplicitlyConfigured() ) {
mainCompileTask.setSourceCompatibility( jdkVersionsConfig.getMainReleaseVersion().toString() );
mainCompileTask.setTargetCompatibility( jdkVersionsConfig.getMainReleaseVersion().toString() );
testCompileTask.setSourceCompatibility( jdkVersionsConfig.getTestCompileVersion().toString() );
testCompileTask.setTargetCompatibility( jdkVersionsConfig.getTestCompileVersion().toString() );
}
else {
javaPluginExtension.getToolchain().getLanguageVersion().set( jdkVersionsConfig.getMainCompileVersion() ); javaPluginExtension.getToolchain().getLanguageVersion().set( jdkVersionsConfig.getMainCompileVersion() );
prepareCompileTask( mainCompileTask, jdkVersionsConfig.getMainCompileVersion() ); configureCompileTasks( project );
prepareCompileTask( testCompileTask, jdkVersionsConfig.getTestCompileVersion() ); configureJavadocTasks( project );
configureCompileTask( mainCompileTask, jdkVersionsConfig.getMainReleaseVersion() );
configureCompileTask( testCompileTask, jdkVersionsConfig.getTestReleaseVersion() );
testCompileTask.getJavaCompiler().set( testCompileTask.getJavaCompiler().set(
toolchainService.compilerFor( new Action<JavaToolchainSpec>() { toolchainService.compilerFor( javaToolchainSpec -> {
@Override javaToolchainSpec.getLanguageVersion().set( jdkVersionsConfig.getTestCompileVersion() );
public void execute(JavaToolchainSpec javaToolchainSpec) {
javaToolchainSpec.getLanguageVersion().set( jdkVersionsConfig.getTestCompileVersion() );
}
} ) } )
); );
}
}
project.getTasks().withType( JavaCompile.class ).configureEach( new Action<JavaCompile>() { private void configureCompileTask(JavaCompile compileTask, JavaLanguageVersion releaseVersion) {
@Override final CompileOptions compileTaskOptions = compileTask.getOptions();
public void execute(JavaCompile compileTask) { compileTaskOptions.getRelease().set( releaseVersion.asInt() );
getJvmArgs( compileTask ).addAll( // Needs add-opens because of https://github.com/gradle/gradle/issues/15538
Arrays.asList( compileTaskOptions.getForkOptions().getJvmArgs().add( "--add-opens" );
project.property( "toolchain.compiler.jvmargs" ).toString().split( " " ) compileTaskOptions.getForkOptions().getJvmArgs().add( "jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED" );
) }
);
compileTask.doFirst( private void configureCompileTasks(Project project) {
new Action<Task>() { project.getTasks().withType( JavaCompile.class ).configureEach( new Action<JavaCompile>() {
@Override @Override
public void execute(Task task) { public void execute(JavaCompile compileTask) {
project.getLogger().lifecycle( getJvmArgs( compileTask ).addAll(
"Compiling with '%s'", Arrays.asList(
compileTask.getJavaCompiler().get().getMetadata().getInstallationPath() project.property( "toolchain.compiler.jvmargs" ).toString().split( " " )
); )
} );
compileTask.doFirst(
new Action<Task>() {
@Override
public void execute(Task task) {
project.getLogger().lifecycle(
"Compiling with '%s'",
compileTask.getJavaCompiler().get().getMetadata().getInstallationPath()
);
} }
); }
} );
} ); }
} );
}
project.getTasks().withType( Javadoc.class ).configureEach( (javadocTask) -> { private void configureJavadocTasks(Project project) {
project.getTasks().withType( Javadoc.class ).configureEach( new Action<Javadoc>() {
@Override
public void execute(Javadoc javadocTask) {
javadocTask.getOptions().setJFlags( javadocFlags( project ) ); javadocTask.getOptions().setJFlags( javadocFlags( project ) );
javadocTask.doFirst( new Action<Task>() { javadocTask.doFirst( new Action<Task>() {
@Override @Override
@ -108,8 +121,8 @@ public class JavaModulePlugin implements Plugin<Project> {
); );
} }
} ); } );
} ); }
} } );
} }
private static List<String> javadocFlags(Project project) { private static List<String> javadocFlags(Project project) {
@ -118,22 +131,6 @@ public class JavaModulePlugin implements Plugin<Project> {
return Arrays.asList( splits ).stream().filter( (split) -> !split.isEmpty() ).collect( Collectors.toList() ); return Arrays.asList( splits ).stream().filter( (split) -> !split.isEmpty() ).collect( Collectors.toList() );
} }
private void prepareCompileTask(JavaCompile compileTask, JavaLanguageVersion version) {
compileTask.getJavaCompiler().set(
toolchainService.compilerFor( new Action<JavaToolchainSpec>() {
@Override
public void execute(JavaToolchainSpec javaToolchainSpec) {
javaToolchainSpec.getLanguageVersion().set( version );
}
} )
);
compileTask.getOptions().getRelease().set( version.asInt() );
// Needs add-opens because of https://github.com/gradle/gradle/issues/15538
getJvmArgs( compileTask ).addAll( asList( "--add-opens", "jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED" ) );
}
public static List<String> getJvmArgs(JavaCompile compileTask) { public static List<String> getJvmArgs(JavaCompile compileTask) {
final List<String> existing = compileTask final List<String> existing = compileTask
.getOptions() .getOptions()