From a87287ba034e1e170f9ad88704025f5dec682d0d Mon Sep 17 00:00:00 2001 From: Michal Karm Babacek Date: Fri, 8 Dec 2023 22:56:02 +0100 Subject: [PATCH] Makes AwtProcessor, the default native-image version --- .../quarkus/awt/deployment/AwtProcessor.java | 29 +++++++++++++++++-- 1 file changed, 26 insertions(+), 3 deletions(-) diff --git a/extensions/awt/deployment/src/main/java/io/quarkus/awt/deployment/AwtProcessor.java b/extensions/awt/deployment/src/main/java/io/quarkus/awt/deployment/AwtProcessor.java index a3b4d06c21221..081b8e5c674e0 100644 --- a/extensions/awt/deployment/src/main/java/io/quarkus/awt/deployment/AwtProcessor.java +++ b/extensions/awt/deployment/src/main/java/io/quarkus/awt/deployment/AwtProcessor.java @@ -1,12 +1,15 @@ package io.quarkus.awt.deployment; import static io.quarkus.deployment.builditem.nativeimage.UnsupportedOSBuildItem.Os.WINDOWS; +import static io.quarkus.deployment.pkg.steps.GraalVM.Version.CURRENT; import java.util.ArrayList; import java.util.List; import java.util.Optional; import java.util.stream.Stream; +import org.jboss.logging.Logger; + import io.quarkus.awt.runtime.graal.DarwinAwtFeature; import io.quarkus.deployment.Feature; import io.quarkus.deployment.annotations.BuildProducer; @@ -26,9 +29,12 @@ import io.quarkus.deployment.pkg.builditem.ProcessInheritIODisabledBuildItem; import io.quarkus.deployment.pkg.steps.GraalVM; import io.quarkus.deployment.pkg.steps.NativeOrNativeSourcesBuild; +import io.quarkus.deployment.pkg.steps.NoopNativeImageBuildRunner; class AwtProcessor { + private static final Logger log = Logger.getLogger(AwtProcessor.class); + @BuildStep FeatureBuildItem feature() { return new FeatureBuildItem(Feature.AWT); @@ -74,6 +80,7 @@ ReflectiveClassBuildItem setupReflectionClasses() { @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) ReflectiveClassBuildItem setupReflectionClassesWithMethods() { + //@formatter:off return ReflectiveClassBuildItem.builder( "javax.imageio.plugins.tiff.BaselineTIFFTagSet", "javax.imageio.plugins.tiff.ExifGPSTagSet", @@ -91,7 +98,9 @@ ReflectiveClassBuildItem setupReflectionClassesWithMethods() { "sun.java2d.loops.SetDrawRectANY", "sun.java2d.loops.SetFillPathANY", "sun.java2d.loops.SetFillRectANY", - "sun.java2d.loops.SetFillSpansANY").methods().build(); + "sun.java2d.loops.SetFillSpansANY" + ).methods().build(); + //@formatter:on } @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) @@ -103,7 +112,14 @@ void setupAWTInit(BuildProducer jc, Optional processInheritIODisabledBuildItem) { nativeImageRunnerBuildItem.getBuildRunner() .setup(processInheritIODisabled.isPresent() || processInheritIODisabledBuildItem.isPresent()); - final GraalVM.Version v = nativeImageRunnerBuildItem.getBuildRunner().getGraalVMVersion(); + final GraalVM.Version v; + if (nativeImageRunnerBuildItem.getBuildRunner() instanceof NoopNativeImageBuildRunner) { + v = CURRENT; + log.warnf("native-image is not installed. " + + "Using the default %s version as a reference to build native-sources step.", v.getVersionAsString()); + } else { + v = nativeImageRunnerBuildItem.getBuildRunner().getGraalVMVersion(); + } // Dynamically loading shared objects instead // of baking in static libs: https://github.com/oracle/graal/issues/4921 if (v.compareTo(GraalVM.Version.VERSION_23_0_0) >= 0) { @@ -130,7 +146,12 @@ JniRuntimeAccessBuildItem setupJava2DClasses(NativeImageRunnerBuildItem nativeIm Optional processInheritIODisabledBuildItem) { nativeImageRunnerBuildItem.getBuildRunner() .setup(processInheritIODisabled.isPresent() || processInheritIODisabledBuildItem.isPresent()); - final GraalVM.Version v = nativeImageRunnerBuildItem.getBuildRunner().getGraalVMVersion(); + final GraalVM.Version v; + if (nativeImageRunnerBuildItem.getBuildRunner() instanceof NoopNativeImageBuildRunner) { + v = CURRENT; + } else { + v = nativeImageRunnerBuildItem.getBuildRunner().getGraalVMVersion(); + } final List classes = new ArrayList<>(); classes.add("com.sun.imageio.plugins.jpeg.JPEGImageReader"); classes.add("com.sun.imageio.plugins.jpeg.JPEGImageWriter"); @@ -283,6 +304,7 @@ void runtimeInitializedClasses(BuildProducer * Note that this initialization is not enough if user wants to deserialize actual images * (e.g. from XML). AWT Extension must be loaded for decoding JDK supported image formats. */ + //@formatter:off Stream.of( "com.sun.imageio", "java.awt", @@ -292,5 +314,6 @@ void runtimeInitializedClasses(BuildProducer "sun.java2d") .map(RuntimeInitializedPackageBuildItem::new) .forEach(runtimeInitilizedPackages::produce); + //@formatter:on } }