You are viewing a plain text version of this content. The canonical link for it is here.
Posted to site-commits@maven.apache.org by bm...@apache.org on 2024/01/29 19:35:36 UTC

svn commit: r1915464 [15/18] - in /maven/website/components/plugins-archives/maven-jlink-plugin-LATEST: ./ apidocs/ apidocs/jquery/ apidocs/legal/ apidocs/org/apache/maven/plugins/jlink/ apidocs/org/apache/maven/plugins/jlink/class-use/ apidocs/org/apa...

Modified: maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html
==============================================================================
--- maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html (original)
+++ maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html Mon Jan 29 19:35:35 2024
@@ -6,212 +6,204 @@
 </head>
 <body>
 <div id="overview"><a href="../../../../../../apidocs/org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html">View Javadoc</a></div><pre>
-<a class="jxr_linenumber" name="L1" href="#L1">1</a>   <strong class="jxr_keyword">package</strong> org.apache.maven.plugins.jlink;
-<a class="jxr_linenumber" name="L2" href="#L2">2</a>   
-<a class="jxr_linenumber" name="L3" href="#L3">3</a>   <em class="jxr_comment">/*</em>
-<a class="jxr_linenumber" name="L4" href="#L4">4</a>   <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
-<a class="jxr_linenumber" name="L5" href="#L5">5</a>   <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
-<a class="jxr_linenumber" name="L6" href="#L6">6</a>   <em class="jxr_comment"> * distributed with this work for additional information</em>
-<a class="jxr_linenumber" name="L7" href="#L7">7</a>   <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
-<a class="jxr_linenumber" name="L8" href="#L8">8</a>   <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
-<a class="jxr_linenumber" name="L9" href="#L9">9</a>   <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
-<a class="jxr_linenumber" name="L10" href="#L10">10</a>  <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L1" href="#L1">1</a>   <em class="jxr_comment">/*</em>
+<a class="jxr_linenumber" name="L2" href="#L2">2</a>   <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
+<a class="jxr_linenumber" name="L3" href="#L3">3</a>   <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
+<a class="jxr_linenumber" name="L4" href="#L4">4</a>   <em class="jxr_comment"> * distributed with this work for additional information</em>
+<a class="jxr_linenumber" name="L5" href="#L5">5</a>   <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
+<a class="jxr_linenumber" name="L6" href="#L6">6</a>   <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
+<a class="jxr_linenumber" name="L7" href="#L7">7</a>   <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
+<a class="jxr_linenumber" name="L8" href="#L8">8</a>   <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L9" href="#L9">9</a>   <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L10" href="#L10">10</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2.0" target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.0</a></em>
 <a class="jxr_linenumber" name="L11" href="#L11">11</a>  <em class="jxr_comment"> *</em>
-<a class="jxr_linenumber" name="L12" href="#L12">12</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2." target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.</a>0</em>
-<a class="jxr_linenumber" name="L13" href="#L13">13</a>  <em class="jxr_comment"> *</em>
-<a class="jxr_linenumber" name="L14" href="#L14">14</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
-<a class="jxr_linenumber" name="L15" href="#L15">15</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
-<a class="jxr_linenumber" name="L16" href="#L16">16</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
-<a class="jxr_linenumber" name="L17" href="#L17">17</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
-<a class="jxr_linenumber" name="L18" href="#L18">18</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
-<a class="jxr_linenumber" name="L19" href="#L19">19</a>  <em class="jxr_comment"> * under the License.</em>
-<a class="jxr_linenumber" name="L20" href="#L20">20</a>  <em class="jxr_comment"> */</em>
-<a class="jxr_linenumber" name="L21" href="#L21">21</a>  
-<a class="jxr_linenumber" name="L22" href="#L22">22</a>  <strong class="jxr_keyword">import</strong> org.apache.commons.lang3.StringUtils;
-<a class="jxr_linenumber" name="L23" href="#L23">23</a>  <strong class="jxr_keyword">import</strong> org.apache.commons.lang3.SystemUtils;
-<a class="jxr_linenumber" name="L24" href="#L24">24</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.MojoExecutionException;
-<a class="jxr_linenumber" name="L25" href="#L25">25</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.logging.Log;
-<a class="jxr_linenumber" name="L26" href="#L26">26</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.CommandLineException;
-<a class="jxr_linenumber" name="L27" href="#L27">27</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.CommandLineUtils;
-<a class="jxr_linenumber" name="L28" href="#L28">28</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.Commandline;
-<a class="jxr_linenumber" name="L29" href="#L29">29</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.toolchain.Toolchain;
-<a class="jxr_linenumber" name="L30" href="#L30">30</a>  
-<a class="jxr_linenumber" name="L31" href="#L31">31</a>  <strong class="jxr_keyword">import</strong> java.io.File;
-<a class="jxr_linenumber" name="L32" href="#L32">32</a>  <strong class="jxr_keyword">import</strong> java.util.List;
-<a class="jxr_linenumber" name="L33" href="#L33">33</a>  <strong class="jxr_keyword">import</strong> java.util.NoSuchElementException;
-<a class="jxr_linenumber" name="L34" href="#L34">34</a>  <strong class="jxr_keyword">import</strong> java.util.Optional;
-<a class="jxr_linenumber" name="L35" href="#L35">35</a>  
-<a class="jxr_linenumber" name="L36" href="#L36">36</a>  <strong class="jxr_keyword">abstract</strong> <strong class="jxr_keyword">class</strong> <a href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html">AbstractJLinkToolchainExecutor</a> <strong class="jxr_keyword">extends</strong> <a href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkExecutor.html">AbstractJLinkExecutor</a>
-<a class="jxr_linenumber" name="L37" href="#L37">37</a>  {
-<a class="jxr_linenumber" name="L38" href="#L38">38</a>      <strong class="jxr_keyword">private</strong> <strong class="jxr_keyword">final</strong> Toolchain toolchain;
+<a class="jxr_linenumber" name="L12" href="#L12">12</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
+<a class="jxr_linenumber" name="L13" href="#L13">13</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
+<a class="jxr_linenumber" name="L14" href="#L14">14</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
+<a class="jxr_linenumber" name="L15" href="#L15">15</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
+<a class="jxr_linenumber" name="L16" href="#L16">16</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
+<a class="jxr_linenumber" name="L17" href="#L17">17</a>  <em class="jxr_comment"> * under the License.</em>
+<a class="jxr_linenumber" name="L18" href="#L18">18</a>  <em class="jxr_comment"> */</em>
+<a class="jxr_linenumber" name="L19" href="#L19">19</a>  <strong class="jxr_keyword">package</strong> org.apache.maven.plugins.jlink;
+<a class="jxr_linenumber" name="L20" href="#L20">20</a>  
+<a class="jxr_linenumber" name="L21" href="#L21">21</a>  <em class="jxr_comment">/*</em>
+<a class="jxr_linenumber" name="L22" href="#L22">22</a>  <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
+<a class="jxr_linenumber" name="L23" href="#L23">23</a>  <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
+<a class="jxr_linenumber" name="L24" href="#L24">24</a>  <em class="jxr_comment"> * distributed with this work for additional information</em>
+<a class="jxr_linenumber" name="L25" href="#L25">25</a>  <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
+<a class="jxr_linenumber" name="L26" href="#L26">26</a>  <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
+<a class="jxr_linenumber" name="L27" href="#L27">27</a>  <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
+<a class="jxr_linenumber" name="L28" href="#L28">28</a>  <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L29" href="#L29">29</a>  <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L30" href="#L30">30</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2.0" target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.0</a></em>
+<a class="jxr_linenumber" name="L31" href="#L31">31</a>  <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L32" href="#L32">32</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
+<a class="jxr_linenumber" name="L33" href="#L33">33</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
+<a class="jxr_linenumber" name="L34" href="#L34">34</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
+<a class="jxr_linenumber" name="L35" href="#L35">35</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
+<a class="jxr_linenumber" name="L36" href="#L36">36</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
+<a class="jxr_linenumber" name="L37" href="#L37">37</a>  <em class="jxr_comment"> * under the License.</em>
+<a class="jxr_linenumber" name="L38" href="#L38">38</a>  <em class="jxr_comment"> */</em>
 <a class="jxr_linenumber" name="L39" href="#L39">39</a>  
-<a class="jxr_linenumber" name="L40" href="#L40">40</a>      <a href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html">AbstractJLinkToolchainExecutor</a>( Toolchain toolchain, Log log )
-<a class="jxr_linenumber" name="L41" href="#L41">41</a>      {
-<a class="jxr_linenumber" name="L42" href="#L42">42</a>          <strong class="jxr_keyword">super</strong>( log );
-<a class="jxr_linenumber" name="L43" href="#L43">43</a>          <strong class="jxr_keyword">this</strong>.toolchain = toolchain;
-<a class="jxr_linenumber" name="L44" href="#L44">44</a>      }
-<a class="jxr_linenumber" name="L45" href="#L45">45</a>  
-<a class="jxr_linenumber" name="L46" href="#L46">46</a>      <strong class="jxr_keyword">protected</strong> Optional&lt;Toolchain&gt; getToolchain()
-<a class="jxr_linenumber" name="L47" href="#L47">47</a>      {
-<a class="jxr_linenumber" name="L48" href="#L48">48</a>          <strong class="jxr_keyword">return</strong> Optional.ofNullable( <strong class="jxr_keyword">this</strong>.toolchain );
-<a class="jxr_linenumber" name="L49" href="#L49">49</a>      }
-<a class="jxr_linenumber" name="L50" href="#L50">50</a>  
-<a class="jxr_linenumber" name="L51" href="#L51">51</a>      <em class="jxr_javadoccomment">/**</em>
-<a class="jxr_linenumber" name="L52" href="#L52">52</a>  <em class="jxr_javadoccomment">     * Execute JLink via toolchain.</em>
-<a class="jxr_linenumber" name="L53" href="#L53">53</a>  <em class="jxr_javadoccomment">     *</em>
-<a class="jxr_linenumber" name="L54" href="#L54">54</a>  <em class="jxr_javadoccomment">     * @return the exit code ({@code 0} on success).</em>
-<a class="jxr_linenumber" name="L55" href="#L55">55</a>  <em class="jxr_javadoccomment">     */</em>
-<a class="jxr_linenumber" name="L56" href="#L56">56</a>      @Override
-<a class="jxr_linenumber" name="L57" href="#L57">57</a>      <strong class="jxr_keyword">public</strong> <strong class="jxr_keyword">int</strong> executeJlink( List&lt;String&gt; jlinkArgs ) <strong class="jxr_keyword">throws</strong> MojoExecutionException
-<a class="jxr_linenumber" name="L58" href="#L58">58</a>      {
-<a class="jxr_linenumber" name="L59" href="#L59">59</a>          File jlinkExecutable = getJlinkExecutable();
-<a class="jxr_linenumber" name="L60" href="#L60">60</a>          getLog().info( <span class="jxr_string">"Toolchain in maven-jlink-plugin: jlink [ "</span> + jlinkExecutable + <span class="jxr_string">" ]"</span> );
+<a class="jxr_linenumber" name="L40" href="#L40">40</a>  <strong class="jxr_keyword">import</strong> java.io.File;
+<a class="jxr_linenumber" name="L41" href="#L41">41</a>  <strong class="jxr_keyword">import</strong> java.util.List;
+<a class="jxr_linenumber" name="L42" href="#L42">42</a>  <strong class="jxr_keyword">import</strong> java.util.NoSuchElementException;
+<a class="jxr_linenumber" name="L43" href="#L43">43</a>  <strong class="jxr_keyword">import</strong> java.util.Optional;
+<a class="jxr_linenumber" name="L44" href="#L44">44</a>  
+<a class="jxr_linenumber" name="L45" href="#L45">45</a>  <strong class="jxr_keyword">import</strong> org.apache.commons.lang3.StringUtils;
+<a class="jxr_linenumber" name="L46" href="#L46">46</a>  <strong class="jxr_keyword">import</strong> org.apache.commons.lang3.SystemUtils;
+<a class="jxr_linenumber" name="L47" href="#L47">47</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.MojoExecutionException;
+<a class="jxr_linenumber" name="L48" href="#L48">48</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.logging.Log;
+<a class="jxr_linenumber" name="L49" href="#L49">49</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.CommandLineException;
+<a class="jxr_linenumber" name="L50" href="#L50">50</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.CommandLineUtils;
+<a class="jxr_linenumber" name="L51" href="#L51">51</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.shared.utils.cli.Commandline;
+<a class="jxr_linenumber" name="L52" href="#L52">52</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.toolchain.Toolchain;
+<a class="jxr_linenumber" name="L53" href="#L53">53</a>  
+<a class="jxr_linenumber" name="L54" href="#L54">54</a>  <strong class="jxr_keyword">abstract</strong> <strong class="jxr_keyword">class</strong> <a name="AbstractJLinkToolchainExecutor" href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html#AbstractJLinkToolchainExecutor">AbstractJLinkToolchainExecutor</a> <strong class="jxr_keyword">extends</strong> <a name="AbstractJLinkExecutor" href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkExecutor.html#AbstractJLinkExecutor">AbstractJLinkExecutor</a> {
+<a class="jxr_linenumber" name="L55" href="#L55">55</a>      <strong class="jxr_keyword">private</strong> <strong class="jxr_keyword">final</strong> Toolchain toolchain;
+<a class="jxr_linenumber" name="L56" href="#L56">56</a>  
+<a class="jxr_linenumber" name="L57" href="#L57">57</a>      <a name="AbstractJLinkToolchainExecutor" href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html#AbstractJLinkToolchainExecutor">AbstractJLinkToolchainExecutor</a>(Toolchain toolchain, Log log) {
+<a class="jxr_linenumber" name="L58" href="#L58">58</a>          <strong class="jxr_keyword">super</strong>(log);
+<a class="jxr_linenumber" name="L59" href="#L59">59</a>          <strong class="jxr_keyword">this</strong>.toolchain = toolchain;
+<a class="jxr_linenumber" name="L60" href="#L60">60</a>      }
 <a class="jxr_linenumber" name="L61" href="#L61">61</a>  
-<a class="jxr_linenumber" name="L62" href="#L62">62</a>          Commandline cmd = createJLinkCommandLine( jlinkArgs );
-<a class="jxr_linenumber" name="L63" href="#L63">63</a>          cmd.setExecutable( jlinkExecutable.getAbsolutePath() );
-<a class="jxr_linenumber" name="L64" href="#L64">64</a>  
-<a class="jxr_linenumber" name="L65" href="#L65">65</a>          <strong class="jxr_keyword">return</strong> executeCommand( cmd );
-<a class="jxr_linenumber" name="L66" href="#L66">66</a>      }
-<a class="jxr_linenumber" name="L67" href="#L67">67</a>  
-<a class="jxr_linenumber" name="L68" href="#L68">68</a>      <strong class="jxr_keyword">private</strong> File getJlinkExecutable()
-<a class="jxr_linenumber" name="L69" href="#L69">69</a>      {
-<a class="jxr_linenumber" name="L70" href="#L70">70</a>          <strong class="jxr_keyword">return</strong> <strong class="jxr_keyword">new</strong> File( getJLinkExecutable() );
-<a class="jxr_linenumber" name="L71" href="#L71">71</a>      }
-<a class="jxr_linenumber" name="L72" href="#L72">72</a>  
-<a class="jxr_linenumber" name="L73" href="#L73">73</a>      @Override
-<a class="jxr_linenumber" name="L74" href="#L74">74</a>      <strong class="jxr_keyword">public</strong> Optional&lt;File&gt; getJmodsFolder( <em class="jxr_comment">/* nullable */</em> File sourceJdkModules )
-<a class="jxr_linenumber" name="L75" href="#L75">75</a>      {
-<a class="jxr_linenumber" name="L76" href="#L76">76</a>          <em class="jxr_comment">// Really Hacky...do we have a better solution to find the jmods directory of the JDK?</em>
-<a class="jxr_linenumber" name="L77" href="#L77">77</a>          File jLinkParent = getJlinkExecutable().getParentFile().getParentFile();
-<a class="jxr_linenumber" name="L78" href="#L78">78</a>          File jmodsFolder;
-<a class="jxr_linenumber" name="L79" href="#L79">79</a>          <strong class="jxr_keyword">if</strong> ( sourceJdkModules != <strong class="jxr_keyword">null</strong> &amp;&amp; sourceJdkModules.isDirectory() )
-<a class="jxr_linenumber" name="L80" href="#L80">80</a>          {
-<a class="jxr_linenumber" name="L81" href="#L81">81</a>              jmodsFolder = <strong class="jxr_keyword">new</strong> File( sourceJdkModules, JMODS );
-<a class="jxr_linenumber" name="L82" href="#L82">82</a>          }
-<a class="jxr_linenumber" name="L83" href="#L83">83</a>          <strong class="jxr_keyword">else</strong>
-<a class="jxr_linenumber" name="L84" href="#L84">84</a>          {
-<a class="jxr_linenumber" name="L85" href="#L85">85</a>              jmodsFolder = <strong class="jxr_keyword">new</strong> File( jLinkParent, JMODS );
-<a class="jxr_linenumber" name="L86" href="#L86">86</a>          }
-<a class="jxr_linenumber" name="L87" href="#L87">87</a>  
-<a class="jxr_linenumber" name="L88" href="#L88">88</a>          getLog().debug( <span class="jxr_string">" Parent: "</span> + jLinkParent.getAbsolutePath() );
-<a class="jxr_linenumber" name="L89" href="#L89">89</a>          getLog().debug( <span class="jxr_string">" jmodsFolder: "</span> + jmodsFolder.getAbsolutePath() );
-<a class="jxr_linenumber" name="L90" href="#L90">90</a>  
-<a class="jxr_linenumber" name="L91" href="#L91">91</a>          <strong class="jxr_keyword">return</strong> Optional.of( jmodsFolder );
-<a class="jxr_linenumber" name="L92" href="#L92">92</a>      }
-<a class="jxr_linenumber" name="L93" href="#L93">93</a>  
-<a class="jxr_linenumber" name="L94" href="#L94">94</a>      <strong class="jxr_keyword">private</strong> Commandline createJLinkCommandLine( List&lt;String&gt; jlinkArgs )
-<a class="jxr_linenumber" name="L95" href="#L95">95</a>      {
-<a class="jxr_linenumber" name="L96" href="#L96">96</a>          Commandline cmd = <strong class="jxr_keyword">new</strong> Commandline();
-<a class="jxr_linenumber" name="L97" href="#L97">97</a>          jlinkArgs.forEach( arg -&gt; cmd.createArg().setValue( arg ) );
-<a class="jxr_linenumber" name="L98" href="#L98">98</a>  
-<a class="jxr_linenumber" name="L99" href="#L99">99</a>          <strong class="jxr_keyword">return</strong> cmd;
-<a class="jxr_linenumber" name="L100" href="#L100">100</a>     }
-<a class="jxr_linenumber" name="L101" href="#L101">101</a> 
-<a class="jxr_linenumber" name="L102" href="#L102">102</a>     <strong class="jxr_keyword">private</strong> String getJLinkExecutable()
-<a class="jxr_linenumber" name="L103" href="#L103">103</a>     {
-<a class="jxr_linenumber" name="L104" href="#L104">104</a>         Optional&lt;Toolchain&gt; toolchain = getToolchain();
-<a class="jxr_linenumber" name="L105" href="#L105">105</a> 
-<a class="jxr_linenumber" name="L106" href="#L106">106</a>         <strong class="jxr_keyword">if</strong> ( !toolchain.isPresent() )
-<a class="jxr_linenumber" name="L107" href="#L107">107</a>         {
-<a class="jxr_linenumber" name="L108" href="#L108">108</a>             getLog().error( <span class="jxr_string">"Either JDK9+ or a toolchain "</span>
-<a class="jxr_linenumber" name="L109" href="#L109">109</a>                     + <span class="jxr_string">"pointing to a JDK9+ containing a jlink binary is required."</span> );
-<a class="jxr_linenumber" name="L110" href="#L110">110</a>             getLog().info( <span class="jxr_string">"See https://maven.apache.org/guides/mini/guide-using-toolchains.html "</span>
-<a class="jxr_linenumber" name="L111" href="#L111">111</a>                     + <span class="jxr_string">"for mor information."</span> );
-<a class="jxr_linenumber" name="L112" href="#L112">112</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException( <span class="jxr_string">"Running on JDK8 and no toolchain found."</span> );
-<a class="jxr_linenumber" name="L113" href="#L113">113</a>         }
-<a class="jxr_linenumber" name="L114" href="#L114">114</a> 
-<a class="jxr_linenumber" name="L115" href="#L115">115</a>         String jLinkExecutable = toolchain.orElseThrow( NoSuchElementException::<strong class="jxr_keyword">new</strong> ).findTool( <span class="jxr_string">"jlink"</span> );
-<a class="jxr_linenumber" name="L116" href="#L116">116</a> 
-<a class="jxr_linenumber" name="L117" href="#L117">117</a>         <strong class="jxr_keyword">if</strong> ( jLinkExecutable.isEmpty() )
-<a class="jxr_linenumber" name="L118" href="#L118">118</a>         {
-<a class="jxr_linenumber" name="L119" href="#L119">119</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException( <span class="jxr_string">"The jlink executable '"</span>
-<a class="jxr_linenumber" name="L120" href="#L120">120</a>                     + jLinkExecutable + <span class="jxr_string">"' doesn't exist or is not a file."</span> );
-<a class="jxr_linenumber" name="L121" href="#L121">121</a>         }
-<a class="jxr_linenumber" name="L122" href="#L122">122</a> 
-<a class="jxr_linenumber" name="L123" href="#L123">123</a>         <em class="jxr_comment">// TODO: Check if there exist a more elegant way?</em>
-<a class="jxr_linenumber" name="L124" href="#L124">124</a>         String jLinkCommand = <span class="jxr_string">"jlink"</span> + ( SystemUtils.IS_OS_WINDOWS ? <span class="jxr_string">".exe"</span> : <span class="jxr_string">""</span> );
-<a class="jxr_linenumber" name="L125" href="#L125">125</a> 
-<a class="jxr_linenumber" name="L126" href="#L126">126</a>         File jLinkExe = <strong class="jxr_keyword">new</strong> File( jLinkExecutable );
-<a class="jxr_linenumber" name="L127" href="#L127">127</a> 
-<a class="jxr_linenumber" name="L128" href="#L128">128</a>         <strong class="jxr_keyword">if</strong> ( jLinkExe.isDirectory() )
-<a class="jxr_linenumber" name="L129" href="#L129">129</a>         {
-<a class="jxr_linenumber" name="L130" href="#L130">130</a>             jLinkExe = <strong class="jxr_keyword">new</strong> File( jLinkExe, jLinkCommand );
-<a class="jxr_linenumber" name="L131" href="#L131">131</a>         }
-<a class="jxr_linenumber" name="L132" href="#L132">132</a> 
-<a class="jxr_linenumber" name="L133" href="#L133">133</a>         <strong class="jxr_keyword">if</strong> ( SystemUtils.IS_OS_WINDOWS &amp;&amp; jLinkExe.getName().indexOf( '.' ) &lt; 0 )
-<a class="jxr_linenumber" name="L134" href="#L134">134</a>         {
-<a class="jxr_linenumber" name="L135" href="#L135">135</a>             jLinkExe = <strong class="jxr_keyword">new</strong> File( jLinkExe.getPath() + <span class="jxr_string">".exe"</span> );
+<a class="jxr_linenumber" name="L62" href="#L62">62</a>      <strong class="jxr_keyword">protected</strong> Optional&lt;Toolchain&gt; getToolchain() {
+<a class="jxr_linenumber" name="L63" href="#L63">63</a>          <strong class="jxr_keyword">return</strong> Optional.ofNullable(<strong class="jxr_keyword">this</strong>.toolchain);
+<a class="jxr_linenumber" name="L64" href="#L64">64</a>      }
+<a class="jxr_linenumber" name="L65" href="#L65">65</a>  
+<a class="jxr_linenumber" name="L66" href="#L66">66</a>      <em class="jxr_javadoccomment">/**</em>
+<a class="jxr_linenumber" name="L67" href="#L67">67</a>  <em class="jxr_javadoccomment">     * Execute JLink via toolchain.</em>
+<a class="jxr_linenumber" name="L68" href="#L68">68</a>  <em class="jxr_javadoccomment">     *</em>
+<a class="jxr_linenumber" name="L69" href="#L69">69</a>  <em class="jxr_javadoccomment">     * @return the exit code ({@code 0} on success).</em>
+<a class="jxr_linenumber" name="L70" href="#L70">70</a>  <em class="jxr_javadoccomment">     */</em>
+<a class="jxr_linenumber" name="L71" href="#L71">71</a>      @Override
+<a class="jxr_linenumber" name="L72" href="#L72">72</a>      <strong class="jxr_keyword">public</strong> <strong class="jxr_keyword">int</strong> executeJlink(List&lt;String&gt; jlinkArgs) <strong class="jxr_keyword">throws</strong> MojoExecutionException {
+<a class="jxr_linenumber" name="L73" href="#L73">73</a>          File jlinkExecutable = getJlinkExecutable();
+<a class="jxr_linenumber" name="L74" href="#L74">74</a>          getLog().info(<span class="jxr_string">"Toolchain in maven-jlink-plugin: jlink [ "</span> + jlinkExecutable + <span class="jxr_string">" ]"</span>);
+<a class="jxr_linenumber" name="L75" href="#L75">75</a>  
+<a class="jxr_linenumber" name="L76" href="#L76">76</a>          Commandline cmd = createJLinkCommandLine(jlinkArgs);
+<a class="jxr_linenumber" name="L77" href="#L77">77</a>          cmd.setExecutable(jlinkExecutable.getAbsolutePath());
+<a class="jxr_linenumber" name="L78" href="#L78">78</a>  
+<a class="jxr_linenumber" name="L79" href="#L79">79</a>          <strong class="jxr_keyword">return</strong> executeCommand(cmd);
+<a class="jxr_linenumber" name="L80" href="#L80">80</a>      }
+<a class="jxr_linenumber" name="L81" href="#L81">81</a>  
+<a class="jxr_linenumber" name="L82" href="#L82">82</a>      <strong class="jxr_keyword">private</strong> File getJlinkExecutable() {
+<a class="jxr_linenumber" name="L83" href="#L83">83</a>          <strong class="jxr_keyword">return</strong> <strong class="jxr_keyword">new</strong> File(getJLinkExecutable());
+<a class="jxr_linenumber" name="L84" href="#L84">84</a>      }
+<a class="jxr_linenumber" name="L85" href="#L85">85</a>  
+<a class="jxr_linenumber" name="L86" href="#L86">86</a>      @Override
+<a class="jxr_linenumber" name="L87" href="#L87">87</a>      <strong class="jxr_keyword">public</strong> Optional&lt;File&gt; getJmodsFolder(<em class="jxr_comment">/* nullable */</em> File sourceJdkModules) {
+<a class="jxr_linenumber" name="L88" href="#L88">88</a>          <em class="jxr_comment">// Really Hacky...do we have a better solution to find the jmods directory of the JDK?</em>
+<a class="jxr_linenumber" name="L89" href="#L89">89</a>          File jLinkParent = getJlinkExecutable().getParentFile().getParentFile();
+<a class="jxr_linenumber" name="L90" href="#L90">90</a>          File jmodsFolder;
+<a class="jxr_linenumber" name="L91" href="#L91">91</a>          <strong class="jxr_keyword">if</strong> (sourceJdkModules != <strong class="jxr_keyword">null</strong> &amp;&amp; sourceJdkModules.isDirectory()) {
+<a class="jxr_linenumber" name="L92" href="#L92">92</a>              jmodsFolder = <strong class="jxr_keyword">new</strong> File(sourceJdkModules, JMODS);
+<a class="jxr_linenumber" name="L93" href="#L93">93</a>          } <strong class="jxr_keyword">else</strong> {
+<a class="jxr_linenumber" name="L94" href="#L94">94</a>              jmodsFolder = <strong class="jxr_keyword">new</strong> File(jLinkParent, JMODS);
+<a class="jxr_linenumber" name="L95" href="#L95">95</a>          }
+<a class="jxr_linenumber" name="L96" href="#L96">96</a>  
+<a class="jxr_linenumber" name="L97" href="#L97">97</a>          getLog().debug(<span class="jxr_string">" Parent: "</span> + jLinkParent.getAbsolutePath());
+<a class="jxr_linenumber" name="L98" href="#L98">98</a>          getLog().debug(<span class="jxr_string">" jmodsFolder: "</span> + jmodsFolder.getAbsolutePath());
+<a class="jxr_linenumber" name="L99" href="#L99">99</a>  
+<a class="jxr_linenumber" name="L100" href="#L100">100</a>         <strong class="jxr_keyword">return</strong> Optional.of(jmodsFolder);
+<a class="jxr_linenumber" name="L101" href="#L101">101</a>     }
+<a class="jxr_linenumber" name="L102" href="#L102">102</a> 
+<a class="jxr_linenumber" name="L103" href="#L103">103</a>     <strong class="jxr_keyword">private</strong> Commandline createJLinkCommandLine(List&lt;String&gt; jlinkArgs) {
+<a class="jxr_linenumber" name="L104" href="#L104">104</a>         Commandline cmd = <strong class="jxr_keyword">new</strong> Commandline();
+<a class="jxr_linenumber" name="L105" href="#L105">105</a>         jlinkArgs.forEach(arg -&gt; cmd.createArg().setValue(<span class="jxr_string">"\&quot;"</span> + arg + <span class="jxr_string">"\&quot;"</span>));
+<a class="jxr_linenumber" name="L106" href="#L106">106</a> 
+<a class="jxr_linenumber" name="L107" href="#L107">107</a>         <strong class="jxr_keyword">return</strong> cmd;
+<a class="jxr_linenumber" name="L108" href="#L108">108</a>     }
+<a class="jxr_linenumber" name="L109" href="#L109">109</a> 
+<a class="jxr_linenumber" name="L110" href="#L110">110</a>     <strong class="jxr_keyword">private</strong> String getJLinkExecutable() {
+<a class="jxr_linenumber" name="L111" href="#L111">111</a>         Optional&lt;Toolchain&gt; toolchain = getToolchain();
+<a class="jxr_linenumber" name="L112" href="#L112">112</a> 
+<a class="jxr_linenumber" name="L113" href="#L113">113</a>         <strong class="jxr_keyword">if</strong> (!toolchain.isPresent()) {
+<a class="jxr_linenumber" name="L114" href="#L114">114</a>             getLog().error(<span class="jxr_string">"Either JDK9+ or a toolchain "</span>
+<a class="jxr_linenumber" name="L115" href="#L115">115</a>                     + <span class="jxr_string">"pointing to a JDK9+ containing a jlink binary is required."</span>);
+<a class="jxr_linenumber" name="L116" href="#L116">116</a>             getLog().info(<span class="jxr_string">"See https://maven.apache.org/guides/mini/guide-using-toolchains.html "</span>
+<a class="jxr_linenumber" name="L117" href="#L117">117</a>                     + <span class="jxr_string">"for mor information."</span>);
+<a class="jxr_linenumber" name="L118" href="#L118">118</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException(<span class="jxr_string">"Running on JDK8 and no toolchain found."</span>);
+<a class="jxr_linenumber" name="L119" href="#L119">119</a>         }
+<a class="jxr_linenumber" name="L120" href="#L120">120</a> 
+<a class="jxr_linenumber" name="L121" href="#L121">121</a>         String jLinkExecutable =
+<a class="jxr_linenumber" name="L122" href="#L122">122</a>                 toolchain.orElseThrow(NoSuchElementException::<strong class="jxr_keyword">new</strong>).findTool(<span class="jxr_string">"jlink"</span>);
+<a class="jxr_linenumber" name="L123" href="#L123">123</a> 
+<a class="jxr_linenumber" name="L124" href="#L124">124</a>         <strong class="jxr_keyword">if</strong> (jLinkExecutable.isEmpty()) {
+<a class="jxr_linenumber" name="L125" href="#L125">125</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException(
+<a class="jxr_linenumber" name="L126" href="#L126">126</a>                     <span class="jxr_string">"The jlink executable '"</span> + jLinkExecutable + <span class="jxr_string">"' doesn't exist or is not a file."</span>);
+<a class="jxr_linenumber" name="L127" href="#L127">127</a>         }
+<a class="jxr_linenumber" name="L128" href="#L128">128</a> 
+<a class="jxr_linenumber" name="L129" href="#L129">129</a>         <em class="jxr_comment">// TODO: Check if there exist a more elegant way?</em>
+<a class="jxr_linenumber" name="L130" href="#L130">130</a>         String jLinkCommand = <span class="jxr_string">"jlink"</span> + (SystemUtils.IS_OS_WINDOWS ? <span class="jxr_string">".exe"</span> : <span class="jxr_string">""</span>);
+<a class="jxr_linenumber" name="L131" href="#L131">131</a> 
+<a class="jxr_linenumber" name="L132" href="#L132">132</a>         File jLinkExe = <strong class="jxr_keyword">new</strong> File(jLinkExecutable);
+<a class="jxr_linenumber" name="L133" href="#L133">133</a> 
+<a class="jxr_linenumber" name="L134" href="#L134">134</a>         <strong class="jxr_keyword">if</strong> (jLinkExe.isDirectory()) {
+<a class="jxr_linenumber" name="L135" href="#L135">135</a>             jLinkExe = <strong class="jxr_keyword">new</strong> File(jLinkExe, jLinkCommand);
 <a class="jxr_linenumber" name="L136" href="#L136">136</a>         }
 <a class="jxr_linenumber" name="L137" href="#L137">137</a> 
-<a class="jxr_linenumber" name="L138" href="#L138">138</a>         <strong class="jxr_keyword">if</strong> ( !jLinkExe.isFile() )
-<a class="jxr_linenumber" name="L139" href="#L139">139</a>         {
-<a class="jxr_linenumber" name="L140" href="#L140">140</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException( <span class="jxr_string">"The jlink executable '"</span>
-<a class="jxr_linenumber" name="L141" href="#L141">141</a>                     + jLinkExe + <span class="jxr_string">"' doesn't exist or is not a file."</span> );
-<a class="jxr_linenumber" name="L142" href="#L142">142</a>         }
-<a class="jxr_linenumber" name="L143" href="#L143">143</a>         <strong class="jxr_keyword">return</strong> jLinkExe.getAbsolutePath();
-<a class="jxr_linenumber" name="L144" href="#L144">144</a>     }
-<a class="jxr_linenumber" name="L145" href="#L145">145</a> 
-<a class="jxr_linenumber" name="L146" href="#L146">146</a>     <strong class="jxr_keyword">private</strong> <strong class="jxr_keyword">int</strong> executeCommand( Commandline cmd )
-<a class="jxr_linenumber" name="L147" href="#L147">147</a>             <strong class="jxr_keyword">throws</strong> MojoExecutionException
-<a class="jxr_linenumber" name="L148" href="#L148">148</a>     {
-<a class="jxr_linenumber" name="L149" href="#L149">149</a>         <strong class="jxr_keyword">if</strong> ( getLog().isDebugEnabled() )
-<a class="jxr_linenumber" name="L150" href="#L150">150</a>         {
-<a class="jxr_linenumber" name="L151" href="#L151">151</a>             <em class="jxr_comment">// no quoted arguments ???</em>
-<a class="jxr_linenumber" name="L152" href="#L152">152</a>             getLog().debug( CommandLineUtils.toString( cmd.getCommandline() ).replaceAll( <span class="jxr_string">"'"</span>, <span class="jxr_string">""</span> ) );
-<a class="jxr_linenumber" name="L153" href="#L153">153</a>         }
-<a class="jxr_linenumber" name="L154" href="#L154">154</a> 
-<a class="jxr_linenumber" name="L155" href="#L155">155</a>         CommandLineUtils.StringStreamConsumer err = <strong class="jxr_keyword">new</strong> CommandLineUtils.StringStreamConsumer();
-<a class="jxr_linenumber" name="L156" href="#L156">156</a>         CommandLineUtils.StringStreamConsumer out = <strong class="jxr_keyword">new</strong> CommandLineUtils.StringStreamConsumer();
-<a class="jxr_linenumber" name="L157" href="#L157">157</a>         <strong class="jxr_keyword">try</strong>
-<a class="jxr_linenumber" name="L158" href="#L158">158</a>         {
-<a class="jxr_linenumber" name="L159" href="#L159">159</a>             <strong class="jxr_keyword">int</strong> exitCode = CommandLineUtils.executeCommandLine( cmd, out, err );
-<a class="jxr_linenumber" name="L160" href="#L160">160</a> 
-<a class="jxr_linenumber" name="L161" href="#L161">161</a>             String output = ( StringUtils.isEmpty( out.getOutput() ) ? <strong class="jxr_keyword">null</strong> : '\n' + out.getOutput().trim() );
+<a class="jxr_linenumber" name="L138" href="#L138">138</a>         <strong class="jxr_keyword">if</strong> (SystemUtils.IS_OS_WINDOWS &amp;&amp; jLinkExe.getName().indexOf('.') &lt; 0) {
+<a class="jxr_linenumber" name="L139" href="#L139">139</a>             jLinkExe = <strong class="jxr_keyword">new</strong> File(jLinkExe.getPath() + <span class="jxr_string">".exe"</span>);
+<a class="jxr_linenumber" name="L140" href="#L140">140</a>         }
+<a class="jxr_linenumber" name="L141" href="#L141">141</a> 
+<a class="jxr_linenumber" name="L142" href="#L142">142</a>         <strong class="jxr_keyword">if</strong> (!jLinkExe.isFile()) {
+<a class="jxr_linenumber" name="L143" href="#L143">143</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> IllegalStateException(<span class="jxr_string">"The jlink executable '"</span> + jLinkExe + <span class="jxr_string">"' doesn't exist or is not a file."</span>);
+<a class="jxr_linenumber" name="L144" href="#L144">144</a>         }
+<a class="jxr_linenumber" name="L145" href="#L145">145</a>         <strong class="jxr_keyword">return</strong> jLinkExe.getAbsolutePath();
+<a class="jxr_linenumber" name="L146" href="#L146">146</a>     }
+<a class="jxr_linenumber" name="L147" href="#L147">147</a> 
+<a class="jxr_linenumber" name="L148" href="#L148">148</a>     <strong class="jxr_keyword">private</strong> <strong class="jxr_keyword">int</strong> executeCommand(Commandline cmd) <strong class="jxr_keyword">throws</strong> MojoExecutionException {
+<a class="jxr_linenumber" name="L149" href="#L149">149</a>         <strong class="jxr_keyword">if</strong> (getLog().isDebugEnabled()) {
+<a class="jxr_linenumber" name="L150" href="#L150">150</a>             <em class="jxr_comment">// no quoted arguments ???</em>
+<a class="jxr_linenumber" name="L151" href="#L151">151</a>             getLog().debug(CommandLineUtils.toString(cmd.getCommandline()).replaceAll(<span class="jxr_string">"'"</span>, <span class="jxr_string">""</span>));
+<a class="jxr_linenumber" name="L152" href="#L152">152</a>         }
+<a class="jxr_linenumber" name="L153" href="#L153">153</a> 
+<a class="jxr_linenumber" name="L154" href="#L154">154</a>         CommandLineUtils.StringStreamConsumer err = <strong class="jxr_keyword">new</strong> CommandLineUtils.StringStreamConsumer();
+<a class="jxr_linenumber" name="L155" href="#L155">155</a>         CommandLineUtils.StringStreamConsumer out = <strong class="jxr_keyword">new</strong> CommandLineUtils.StringStreamConsumer();
+<a class="jxr_linenumber" name="L156" href="#L156">156</a>         <strong class="jxr_keyword">try</strong> {
+<a class="jxr_linenumber" name="L157" href="#L157">157</a>             <strong class="jxr_keyword">int</strong> exitCode = CommandLineUtils.executeCommandLine(cmd, out, err);
+<a class="jxr_linenumber" name="L158" href="#L158">158</a> 
+<a class="jxr_linenumber" name="L159" href="#L159">159</a>             String output = StringUtils.isEmpty(out.getOutput())
+<a class="jxr_linenumber" name="L160" href="#L160">160</a>                     ? <strong class="jxr_keyword">null</strong>
+<a class="jxr_linenumber" name="L161" href="#L161">161</a>                     : '\n' + out.getOutput().trim();
 <a class="jxr_linenumber" name="L162" href="#L162">162</a> 
-<a class="jxr_linenumber" name="L163" href="#L163">163</a>             <strong class="jxr_keyword">if</strong> ( exitCode != 0 )
-<a class="jxr_linenumber" name="L164" href="#L164">164</a>             {
-<a class="jxr_linenumber" name="L165" href="#L165">165</a> 
-<a class="jxr_linenumber" name="L166" href="#L166">166</a>                 <strong class="jxr_keyword">if</strong> ( StringUtils.isNotEmpty( output ) )
-<a class="jxr_linenumber" name="L167" href="#L167">167</a>                 {
-<a class="jxr_linenumber" name="L168" href="#L168">168</a>                     <em class="jxr_comment">// Reconsider to use WARN / ERROR ?</em>
-<a class="jxr_linenumber" name="L169" href="#L169">169</a>                     <em class="jxr_comment">//  getLog().error( output );</em>
-<a class="jxr_linenumber" name="L170" href="#L170">170</a>                     <strong class="jxr_keyword">for</strong> ( String outputLine : output.split( <span class="jxr_string">"\n"</span> ) )
-<a class="jxr_linenumber" name="L171" href="#L171">171</a>                     {
-<a class="jxr_linenumber" name="L172" href="#L172">172</a>                         getLog().error( outputLine );
-<a class="jxr_linenumber" name="L173" href="#L173">173</a>                     }
-<a class="jxr_linenumber" name="L174" href="#L174">174</a>                 }
-<a class="jxr_linenumber" name="L175" href="#L175">175</a> 
-<a class="jxr_linenumber" name="L176" href="#L176">176</a>                 StringBuilder msg = <strong class="jxr_keyword">new</strong> StringBuilder( <span class="jxr_string">"\nExit code: "</span> );
-<a class="jxr_linenumber" name="L177" href="#L177">177</a>                 msg.append( exitCode );
-<a class="jxr_linenumber" name="L178" href="#L178">178</a>                 <strong class="jxr_keyword">if</strong> ( StringUtils.isNotEmpty( err.getOutput() ) )
-<a class="jxr_linenumber" name="L179" href="#L179">179</a>                 {
-<a class="jxr_linenumber" name="L180" href="#L180">180</a>                     msg.append( <span class="jxr_string">" - "</span> ).append( err.getOutput() );
-<a class="jxr_linenumber" name="L181" href="#L181">181</a>                 }
-<a class="jxr_linenumber" name="L182" href="#L182">182</a>                 msg.append( '\n' );
-<a class="jxr_linenumber" name="L183" href="#L183">183</a>                 msg.append( <span class="jxr_string">"Command line was: "</span> ).append( cmd ).append( '\n' ).append( '\n' );
-<a class="jxr_linenumber" name="L184" href="#L184">184</a> 
-<a class="jxr_linenumber" name="L185" href="#L185">185</a>                 <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException( msg.toString() );
-<a class="jxr_linenumber" name="L186" href="#L186">186</a>             }
-<a class="jxr_linenumber" name="L187" href="#L187">187</a> 
-<a class="jxr_linenumber" name="L188" href="#L188">188</a>             <strong class="jxr_keyword">if</strong> ( StringUtils.isNotEmpty( output ) )
-<a class="jxr_linenumber" name="L189" href="#L189">189</a>             {
-<a class="jxr_linenumber" name="L190" href="#L190">190</a>                 <em class="jxr_comment">//getLog().info( output );</em>
-<a class="jxr_linenumber" name="L191" href="#L191">191</a>                 <strong class="jxr_keyword">for</strong> ( String outputLine : output.split( <span class="jxr_string">"\n"</span> ) )
-<a class="jxr_linenumber" name="L192" href="#L192">192</a>                 {
-<a class="jxr_linenumber" name="L193" href="#L193">193</a>                     getLog().info( outputLine );
-<a class="jxr_linenumber" name="L194" href="#L194">194</a>                 }
-<a class="jxr_linenumber" name="L195" href="#L195">195</a>             }
-<a class="jxr_linenumber" name="L196" href="#L196">196</a> 
-<a class="jxr_linenumber" name="L197" href="#L197">197</a>             <strong class="jxr_keyword">return</strong> exitCode;
-<a class="jxr_linenumber" name="L198" href="#L198">198</a>         }
-<a class="jxr_linenumber" name="L199" href="#L199">199</a>         <strong class="jxr_keyword">catch</strong> ( CommandLineException e )
-<a class="jxr_linenumber" name="L200" href="#L200">200</a>         {
-<a class="jxr_linenumber" name="L201" href="#L201">201</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException( <span class="jxr_string">"Unable to execute jlink command: "</span> + e.getMessage(), e );
-<a class="jxr_linenumber" name="L202" href="#L202">202</a>         }
-<a class="jxr_linenumber" name="L203" href="#L203">203</a>     }
-<a class="jxr_linenumber" name="L204" href="#L204">204</a> }
+<a class="jxr_linenumber" name="L163" href="#L163">163</a>             <strong class="jxr_keyword">if</strong> (exitCode != 0) {
+<a class="jxr_linenumber" name="L164" href="#L164">164</a> 
+<a class="jxr_linenumber" name="L165" href="#L165">165</a>                 <strong class="jxr_keyword">if</strong> (output != <strong class="jxr_keyword">null</strong> &amp;&amp; !output.isEmpty()) {
+<a class="jxr_linenumber" name="L166" href="#L166">166</a>                     <em class="jxr_comment">// Reconsider to use WARN / ERROR ?</em>
+<a class="jxr_linenumber" name="L167" href="#L167">167</a>                     <em class="jxr_comment">//  getLog().error( output );</em>
+<a class="jxr_linenumber" name="L168" href="#L168">168</a>                     <strong class="jxr_keyword">for</strong> (String outputLine : output.split(<span class="jxr_string">"\n"</span>)) {
+<a class="jxr_linenumber" name="L169" href="#L169">169</a>                         getLog().error(outputLine);
+<a class="jxr_linenumber" name="L170" href="#L170">170</a>                     }
+<a class="jxr_linenumber" name="L171" href="#L171">171</a>                 }
+<a class="jxr_linenumber" name="L172" href="#L172">172</a> 
+<a class="jxr_linenumber" name="L173" href="#L173">173</a>                 StringBuilder msg = <strong class="jxr_keyword">new</strong> StringBuilder(<span class="jxr_string">"\nExit code: "</span>);
+<a class="jxr_linenumber" name="L174" href="#L174">174</a>                 msg.append(exitCode);
+<a class="jxr_linenumber" name="L175" href="#L175">175</a>                 <strong class="jxr_keyword">if</strong> (StringUtils.isNotEmpty(err.getOutput())) {
+<a class="jxr_linenumber" name="L176" href="#L176">176</a>                     msg.append(<span class="jxr_string">" - "</span>).append(err.getOutput());
+<a class="jxr_linenumber" name="L177" href="#L177">177</a>                 }
+<a class="jxr_linenumber" name="L178" href="#L178">178</a>                 msg.append('\n');
+<a class="jxr_linenumber" name="L179" href="#L179">179</a>                 msg.append(<span class="jxr_string">"Command line was: "</span>).append(cmd).append('\n').append('\n');
+<a class="jxr_linenumber" name="L180" href="#L180">180</a> 
+<a class="jxr_linenumber" name="L181" href="#L181">181</a>                 <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException(msg.toString());
+<a class="jxr_linenumber" name="L182" href="#L182">182</a>             }
+<a class="jxr_linenumber" name="L183" href="#L183">183</a> 
+<a class="jxr_linenumber" name="L184" href="#L184">184</a>             <strong class="jxr_keyword">if</strong> (output != <strong class="jxr_keyword">null</strong> &amp;&amp; !output.isEmpty()) {
+<a class="jxr_linenumber" name="L185" href="#L185">185</a>                 <em class="jxr_comment">// getLog().info( output );</em>
+<a class="jxr_linenumber" name="L186" href="#L186">186</a>                 <strong class="jxr_keyword">for</strong> (String outputLine : output.split(<span class="jxr_string">"\n"</span>)) {
+<a class="jxr_linenumber" name="L187" href="#L187">187</a>                     getLog().info(outputLine);
+<a class="jxr_linenumber" name="L188" href="#L188">188</a>                 }
+<a class="jxr_linenumber" name="L189" href="#L189">189</a>             }
+<a class="jxr_linenumber" name="L190" href="#L190">190</a> 
+<a class="jxr_linenumber" name="L191" href="#L191">191</a>             <strong class="jxr_keyword">return</strong> exitCode;
+<a class="jxr_linenumber" name="L192" href="#L192">192</a>         } <strong class="jxr_keyword">catch</strong> (CommandLineException e) {
+<a class="jxr_linenumber" name="L193" href="#L193">193</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException(<span class="jxr_string">"Unable to execute jlink command: "</span> + e.getMessage(), e);
+<a class="jxr_linenumber" name="L194" href="#L194">194</a>         }
+<a class="jxr_linenumber" name="L195" href="#L195">195</a>     }
+<a class="jxr_linenumber" name="L196" href="#L196">196</a> }
 </pre>
 <hr/>
-<div id="footer">Copyright &#169; 2016&#x2013;2020 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</div>
+<div id="footer">Copyright &#169; 2016&#x2013;2024 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</div>
 </body>
 </html>
\ No newline at end of file

Modified: maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/JLinkExecutor.html
==============================================================================
--- maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/JLinkExecutor.html (original)
+++ maven/website/components/plugins-archives/maven-jlink-plugin-LATEST/xref/org/apache/maven/plugins/jlink/JLinkExecutor.html Mon Jan 29 19:35:35 2024
@@ -6,45 +6,152 @@
 </head>
 <body>
 <div id="overview"><a href="../../../../../../apidocs/org/apache/maven/plugins/jlink/JLinkExecutor.html">View Javadoc</a></div><pre>
-<a class="jxr_linenumber" name="L1" href="#L1">1</a>   <strong class="jxr_keyword">package</strong> org.apache.maven.plugins.jlink;
-<a class="jxr_linenumber" name="L2" href="#L2">2</a>   
-<a class="jxr_linenumber" name="L3" href="#L3">3</a>   <em class="jxr_comment">/*</em>
-<a class="jxr_linenumber" name="L4" href="#L4">4</a>   <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
-<a class="jxr_linenumber" name="L5" href="#L5">5</a>   <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
-<a class="jxr_linenumber" name="L6" href="#L6">6</a>   <em class="jxr_comment"> * distributed with this work for additional information</em>
-<a class="jxr_linenumber" name="L7" href="#L7">7</a>   <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
-<a class="jxr_linenumber" name="L8" href="#L8">8</a>   <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
-<a class="jxr_linenumber" name="L9" href="#L9">9</a>   <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
-<a class="jxr_linenumber" name="L10" href="#L10">10</a>  <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L1" href="#L1">1</a>   <em class="jxr_comment">/*</em>
+<a class="jxr_linenumber" name="L2" href="#L2">2</a>   <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
+<a class="jxr_linenumber" name="L3" href="#L3">3</a>   <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
+<a class="jxr_linenumber" name="L4" href="#L4">4</a>   <em class="jxr_comment"> * distributed with this work for additional information</em>
+<a class="jxr_linenumber" name="L5" href="#L5">5</a>   <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
+<a class="jxr_linenumber" name="L6" href="#L6">6</a>   <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
+<a class="jxr_linenumber" name="L7" href="#L7">7</a>   <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
+<a class="jxr_linenumber" name="L8" href="#L8">8</a>   <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L9" href="#L9">9</a>   <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L10" href="#L10">10</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2.0" target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.0</a></em>
 <a class="jxr_linenumber" name="L11" href="#L11">11</a>  <em class="jxr_comment"> *</em>
-<a class="jxr_linenumber" name="L12" href="#L12">12</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2." target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.</a>0</em>
-<a class="jxr_linenumber" name="L13" href="#L13">13</a>  <em class="jxr_comment"> *</em>
-<a class="jxr_linenumber" name="L14" href="#L14">14</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
-<a class="jxr_linenumber" name="L15" href="#L15">15</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
-<a class="jxr_linenumber" name="L16" href="#L16">16</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
-<a class="jxr_linenumber" name="L17" href="#L17">17</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
-<a class="jxr_linenumber" name="L18" href="#L18">18</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
-<a class="jxr_linenumber" name="L19" href="#L19">19</a>  <em class="jxr_comment"> * under the License.</em>
-<a class="jxr_linenumber" name="L20" href="#L20">20</a>  <em class="jxr_comment"> */</em>
-<a class="jxr_linenumber" name="L21" href="#L21">21</a>  
-<a class="jxr_linenumber" name="L22" href="#L22">22</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.logging.Log;
-<a class="jxr_linenumber" name="L23" href="#L23">23</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.toolchain.Toolchain;
-<a class="jxr_linenumber" name="L24" href="#L24">24</a>  
-<a class="jxr_linenumber" name="L25" href="#L25">25</a>  <em class="jxr_javadoccomment">/**</em>
-<a class="jxr_linenumber" name="L26" href="#L26">26</a>  <em class="jxr_javadoccomment"> * JDK 8-only Jlink executor.</em>
-<a class="jxr_linenumber" name="L27" href="#L27">27</a>  <em class="jxr_javadoccomment"> *</em>
-<a class="jxr_linenumber" name="L28" href="#L28">28</a>  <em class="jxr_javadoccomment"> * &lt;p&gt;As JDK8 does not ship jlink, a toolchain is required.&lt;/p&gt;</em>
-<a class="jxr_linenumber" name="L29" href="#L29">29</a>  <em class="jxr_javadoccomment"> */</em>
-<a class="jxr_linenumber" name="L30" href="#L30">30</a>  <strong class="jxr_keyword">class</strong> <a href="../../../../../org/apache/maven/plugins/jlink/JLinkExecutor.html">JLinkExecutor</a> <strong class="jxr_keyword">extends</strong> <a href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html">AbstractJLinkToolchainExecutor</a>
-<a class="jxr_linenumber" name="L31" href="#L31">31</a>  {
-<a class="jxr_linenumber" name="L32" href="#L32">32</a>      <a href="../../../../../org/apache/maven/plugins/jlink/JLinkExecutor.html">JLinkExecutor</a>( Toolchain toolchain, Log log )
-<a class="jxr_linenumber" name="L33" href="#L33">33</a>      {
-<a class="jxr_linenumber" name="L34" href="#L34">34</a>          <strong class="jxr_keyword">super</strong>( toolchain, log );
-<a class="jxr_linenumber" name="L35" href="#L35">35</a>      }
-<a class="jxr_linenumber" name="L36" href="#L36">36</a>  
-<a class="jxr_linenumber" name="L37" href="#L37">37</a>  }
+<a class="jxr_linenumber" name="L12" href="#L12">12</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
+<a class="jxr_linenumber" name="L13" href="#L13">13</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
+<a class="jxr_linenumber" name="L14" href="#L14">14</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
+<a class="jxr_linenumber" name="L15" href="#L15">15</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
+<a class="jxr_linenumber" name="L16" href="#L16">16</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
+<a class="jxr_linenumber" name="L17" href="#L17">17</a>  <em class="jxr_comment"> * under the License.</em>
+<a class="jxr_linenumber" name="L18" href="#L18">18</a>  <em class="jxr_comment"> */</em>
+<a class="jxr_linenumber" name="L19" href="#L19">19</a>  <strong class="jxr_keyword">package</strong> org.apache.maven.plugins.jlink;
+<a class="jxr_linenumber" name="L20" href="#L20">20</a>  
+<a class="jxr_linenumber" name="L21" href="#L21">21</a>  <em class="jxr_comment">/*</em>
+<a class="jxr_linenumber" name="L22" href="#L22">22</a>  <em class="jxr_comment"> * Licensed to the Apache Software Foundation (ASF) under one</em>
+<a class="jxr_linenumber" name="L23" href="#L23">23</a>  <em class="jxr_comment"> * or more contributor license agreements.  See the NOTICE file</em>
+<a class="jxr_linenumber" name="L24" href="#L24">24</a>  <em class="jxr_comment"> * distributed with this work for additional information</em>
+<a class="jxr_linenumber" name="L25" href="#L25">25</a>  <em class="jxr_comment"> * regarding copyright ownership.  The ASF licenses this file</em>
+<a class="jxr_linenumber" name="L26" href="#L26">26</a>  <em class="jxr_comment"> * to you under the Apache License, Version 2.0 (the</em>
+<a class="jxr_linenumber" name="L27" href="#L27">27</a>  <em class="jxr_comment"> * "License"); you may not use this file except in compliance</em>
+<a class="jxr_linenumber" name="L28" href="#L28">28</a>  <em class="jxr_comment"> * with the License.  You may obtain a copy of the License at</em>
+<a class="jxr_linenumber" name="L29" href="#L29">29</a>  <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L30" href="#L30">30</a>  <em class="jxr_comment"> *   <a href="http://www.apache.org/licenses/LICENSE-2.0" target="alexandria_uri">http://www.apache.org/licenses/LICENSE-2.0</a></em>
+<a class="jxr_linenumber" name="L31" href="#L31">31</a>  <em class="jxr_comment"> *</em>
+<a class="jxr_linenumber" name="L32" href="#L32">32</a>  <em class="jxr_comment"> * Unless required by applicable law or agreed to in writing,</em>
+<a class="jxr_linenumber" name="L33" href="#L33">33</a>  <em class="jxr_comment"> * software distributed under the License is distributed on an</em>
+<a class="jxr_linenumber" name="L34" href="#L34">34</a>  <em class="jxr_comment"> * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</em>
+<a class="jxr_linenumber" name="L35" href="#L35">35</a>  <em class="jxr_comment"> * KIND, either express or implied.  See the License for the</em>
+<a class="jxr_linenumber" name="L36" href="#L36">36</a>  <em class="jxr_comment"> * specific language governing permissions and limitations</em>
+<a class="jxr_linenumber" name="L37" href="#L37">37</a>  <em class="jxr_comment"> * under the License.</em>
+<a class="jxr_linenumber" name="L38" href="#L38">38</a>  <em class="jxr_comment"> */</em>
+<a class="jxr_linenumber" name="L39" href="#L39">39</a>  
+<a class="jxr_linenumber" name="L40" href="#L40">40</a>  <strong class="jxr_keyword">import</strong> java.io.File;
+<a class="jxr_linenumber" name="L41" href="#L41">41</a>  <strong class="jxr_keyword">import</strong> java.io.IOException;
+<a class="jxr_linenumber" name="L42" href="#L42">42</a>  <strong class="jxr_keyword">import</strong> java.io.PrintWriter;
+<a class="jxr_linenumber" name="L43" href="#L43">43</a>  <strong class="jxr_keyword">import</strong> java.io.StringWriter;
+<a class="jxr_linenumber" name="L44" href="#L44">44</a>  <strong class="jxr_keyword">import</strong> java.util.List;
+<a class="jxr_linenumber" name="L45" href="#L45">45</a>  <strong class="jxr_keyword">import</strong> java.util.Optional;
+<a class="jxr_linenumber" name="L46" href="#L46">46</a>  <strong class="jxr_keyword">import</strong> java.util.spi.ToolProvider;
+<a class="jxr_linenumber" name="L47" href="#L47">47</a>  
+<a class="jxr_linenumber" name="L48" href="#L48">48</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.MojoExecutionException;
+<a class="jxr_linenumber" name="L49" href="#L49">49</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.plugin.logging.Log;
+<a class="jxr_linenumber" name="L50" href="#L50">50</a>  <strong class="jxr_keyword">import</strong> org.apache.maven.toolchain.Toolchain;
+<a class="jxr_linenumber" name="L51" href="#L51">51</a>  
+<a class="jxr_linenumber" name="L52" href="#L52">52</a>  <em class="jxr_javadoccomment">/**</em>
+<a class="jxr_linenumber" name="L53" href="#L53">53</a>  <em class="jxr_javadoccomment"> * JDK9+ executor for jlink.</em>
+<a class="jxr_linenumber" name="L54" href="#L54">54</a>  <em class="jxr_javadoccomment"> *</em>
+<a class="jxr_linenumber" name="L55" href="#L55">55</a>  <em class="jxr_javadoccomment"> * &lt;p&gt;This implementation uses the JDK9+ Toolprovider SPI to find and execute jlink.</em>
+<a class="jxr_linenumber" name="L56" href="#L56">56</a>  <em class="jxr_javadoccomment"> * This way, no fork needs to be created.&lt;/p&gt;</em>
+<a class="jxr_linenumber" name="L57" href="#L57">57</a>  <em class="jxr_javadoccomment"> */</em>
+<a class="jxr_linenumber" name="L58" href="#L58">58</a>  <strong class="jxr_keyword">class</strong> <a name="JLinkExecutor" href="../../../../../org/apache/maven/plugins/jlink/JLinkExecutor.html#JLinkExecutor">JLinkExecutor</a> <strong class="jxr_keyword">extends</strong> <a name="AbstractJLinkToolchainExecutor" href="../../../../../org/apache/maven/plugins/jlink/AbstractJLinkToolchainExecutor.html#AbstractJLinkToolchainExecutor">AbstractJLinkToolchainExecutor</a> {
+<a class="jxr_linenumber" name="L59" href="#L59">59</a>      <strong class="jxr_keyword">private</strong> <strong class="jxr_keyword">final</strong> ToolProvider toolProvider;
+<a class="jxr_linenumber" name="L60" href="#L60">60</a>  
+<a class="jxr_linenumber" name="L61" href="#L61">61</a>      <a name="JLinkExecutor" href="../../../../../org/apache/maven/plugins/jlink/JLinkExecutor.html#JLinkExecutor">JLinkExecutor</a>(Toolchain toolchain, Log log) {
+<a class="jxr_linenumber" name="L62" href="#L62">62</a>          <strong class="jxr_keyword">super</strong>(toolchain, log);
+<a class="jxr_linenumber" name="L63" href="#L63">63</a>          <strong class="jxr_keyword">this</strong>.toolProvider = getJLinkExecutable();
+<a class="jxr_linenumber" name="L64" href="#L64">64</a>      }
+<a class="jxr_linenumber" name="L65" href="#L65">65</a>  
+<a class="jxr_linenumber" name="L66" href="#L66">66</a>      <strong class="jxr_keyword">protected</strong> <strong class="jxr_keyword">final</strong> ToolProvider getJLinkExecutable() {
+<a class="jxr_linenumber" name="L67" href="#L67">67</a>          <strong class="jxr_keyword">return</strong> ToolProvider.findFirst(<span class="jxr_string">"jlink"</span>).orElseThrow(() -&gt; <strong class="jxr_keyword">new</strong> IllegalStateException(<span class="jxr_string">"No jlink tool found."</span>));
+<a class="jxr_linenumber" name="L68" href="#L68">68</a>      }
+<a class="jxr_linenumber" name="L69" href="#L69">69</a>  
+<a class="jxr_linenumber" name="L70" href="#L70">70</a>      @Override
+<a class="jxr_linenumber" name="L71" href="#L71">71</a>      <strong class="jxr_keyword">public</strong> <strong class="jxr_keyword">int</strong> executeJlink(List&lt;String&gt; jlinkArgs) <strong class="jxr_keyword">throws</strong> MojoExecutionException {
+<a class="jxr_linenumber" name="L72" href="#L72">72</a>          <strong class="jxr_keyword">if</strong> (getToolchain().isPresent()) {
+<a class="jxr_linenumber" name="L73" href="#L73">73</a>              <strong class="jxr_keyword">return</strong> <strong class="jxr_keyword">super</strong>.executeJlink(jlinkArgs);
+<a class="jxr_linenumber" name="L74" href="#L74">74</a>          }
+<a class="jxr_linenumber" name="L75" href="#L75">75</a>  
+<a class="jxr_linenumber" name="L76" href="#L76">76</a>          <strong class="jxr_keyword">if</strong> (getLog().isDebugEnabled()) {
+<a class="jxr_linenumber" name="L77" href="#L77">77</a>              <em class="jxr_comment">// no quoted arguments ???</em>
+<a class="jxr_linenumber" name="L78" href="#L78">78</a>              getLog().debug(<strong class="jxr_keyword">this</strong>.toolProvider.name() + <span class="jxr_string">" "</span> + jlinkArgs);
+<a class="jxr_linenumber" name="L79" href="#L79">79</a>          }
+<a class="jxr_linenumber" name="L80" href="#L80">80</a>  
+<a class="jxr_linenumber" name="L81" href="#L81">81</a>          <strong class="jxr_keyword">try</strong> (StringWriter strErr = <strong class="jxr_keyword">new</strong> StringWriter();
+<a class="jxr_linenumber" name="L82" href="#L82">82</a>                  PrintWriter err = <strong class="jxr_keyword">new</strong> PrintWriter(strErr);
+<a class="jxr_linenumber" name="L83" href="#L83">83</a>                  StringWriter strOut = <strong class="jxr_keyword">new</strong> StringWriter();
+<a class="jxr_linenumber" name="L84" href="#L84">84</a>                  PrintWriter out = <strong class="jxr_keyword">new</strong> PrintWriter(strOut)) {
+<a class="jxr_linenumber" name="L85" href="#L85">85</a>              <strong class="jxr_keyword">int</strong> exitCode = <strong class="jxr_keyword">this</strong>.toolProvider.run(out, err, jlinkArgs.toArray(<strong class="jxr_keyword">new</strong> String[0]));
+<a class="jxr_linenumber" name="L86" href="#L86">86</a>              out.flush();
+<a class="jxr_linenumber" name="L87" href="#L87">87</a>              err.flush();
+<a class="jxr_linenumber" name="L88" href="#L88">88</a>  
+<a class="jxr_linenumber" name="L89" href="#L89">89</a>              String outAsString = strOut.toString();
+<a class="jxr_linenumber" name="L90" href="#L90">90</a>              String output = outAsString.isBlank() ? <strong class="jxr_keyword">null</strong> : '\n' + outAsString.trim();
+<a class="jxr_linenumber" name="L91" href="#L91">91</a>  
+<a class="jxr_linenumber" name="L92" href="#L92">92</a>              <strong class="jxr_keyword">if</strong> (exitCode != 0) {
+<a class="jxr_linenumber" name="L93" href="#L93">93</a>                  <strong class="jxr_keyword">if</strong> (output != <strong class="jxr_keyword">null</strong> &amp;&amp; !output.isBlank()) {
+<a class="jxr_linenumber" name="L94" href="#L94">94</a>                      <em class="jxr_comment">// Reconsider to use WARN / ERROR ?</em>
+<a class="jxr_linenumber" name="L95" href="#L95">95</a>                      <em class="jxr_comment">//  getLog().error( output );</em>
+<a class="jxr_linenumber" name="L96" href="#L96">96</a>                      <strong class="jxr_keyword">for</strong> (String outputLine : output.split(<span class="jxr_string">"\n"</span>)) {
+<a class="jxr_linenumber" name="L97" href="#L97">97</a>                          getLog().error(outputLine);
+<a class="jxr_linenumber" name="L98" href="#L98">98</a>                      }
+<a class="jxr_linenumber" name="L99" href="#L99">99</a>                  }
+<a class="jxr_linenumber" name="L100" href="#L100">100</a> 
+<a class="jxr_linenumber" name="L101" href="#L101">101</a>                 StringBuilder msg = <strong class="jxr_keyword">new</strong> StringBuilder(<span class="jxr_string">"\nExit code: "</span>);
+<a class="jxr_linenumber" name="L102" href="#L102">102</a>                 msg.append(exitCode);
+<a class="jxr_linenumber" name="L103" href="#L103">103</a>                 String errAsString = strErr.toString();
+<a class="jxr_linenumber" name="L104" href="#L104">104</a>                 <strong class="jxr_keyword">if</strong> (errAsString != <strong class="jxr_keyword">null</strong> &amp;&amp; !errAsString.isBlank()) {
+<a class="jxr_linenumber" name="L105" href="#L105">105</a>                     msg.append(<span class="jxr_string">" - "</span>).append(errAsString);
+<a class="jxr_linenumber" name="L106" href="#L106">106</a>                 }
+<a class="jxr_linenumber" name="L107" href="#L107">107</a>                 msg.append('\n');
+<a class="jxr_linenumber" name="L108" href="#L108">108</a>                 msg.append(<span class="jxr_string">"Command line was: "</span>)
+<a class="jxr_linenumber" name="L109" href="#L109">109</a>                         .append(<strong class="jxr_keyword">this</strong>.toolProvider.name())
+<a class="jxr_linenumber" name="L110" href="#L110">110</a>                         .append(' ')
+<a class="jxr_linenumber" name="L111" href="#L111">111</a>                         .append(jlinkArgs)
+<a class="jxr_linenumber" name="L112" href="#L112">112</a>                         .append('\n')
+<a class="jxr_linenumber" name="L113" href="#L113">113</a>                         .append('\n');
+<a class="jxr_linenumber" name="L114" href="#L114">114</a> 
+<a class="jxr_linenumber" name="L115" href="#L115">115</a>                 <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException(msg.toString());
+<a class="jxr_linenumber" name="L116" href="#L116">116</a>             }
+<a class="jxr_linenumber" name="L117" href="#L117">117</a> 
+<a class="jxr_linenumber" name="L118" href="#L118">118</a>             <strong class="jxr_keyword">if</strong> (output != <strong class="jxr_keyword">null</strong> &amp;&amp; !output.isBlank()) {
+<a class="jxr_linenumber" name="L119" href="#L119">119</a>                 <em class="jxr_comment">// getLog().info( output );</em>
+<a class="jxr_linenumber" name="L120" href="#L120">120</a>                 <strong class="jxr_keyword">for</strong> (String outputLine : output.split(<span class="jxr_string">"\n"</span>)) {
+<a class="jxr_linenumber" name="L121" href="#L121">121</a>                     getLog().info(outputLine);
+<a class="jxr_linenumber" name="L122" href="#L122">122</a>                 }
+<a class="jxr_linenumber" name="L123" href="#L123">123</a>             }
+<a class="jxr_linenumber" name="L124" href="#L124">124</a> 
+<a class="jxr_linenumber" name="L125" href="#L125">125</a>             <strong class="jxr_keyword">return</strong> exitCode;
+<a class="jxr_linenumber" name="L126" href="#L126">126</a>         } <strong class="jxr_keyword">catch</strong> (IOException e) {
+<a class="jxr_linenumber" name="L127" href="#L127">127</a>             <strong class="jxr_keyword">throw</strong> <strong class="jxr_keyword">new</strong> MojoExecutionException(<span class="jxr_string">"Unable to execute jlink command: "</span> + e.getMessage(), e);
+<a class="jxr_linenumber" name="L128" href="#L128">128</a>         }
+<a class="jxr_linenumber" name="L129" href="#L129">129</a>     }
+<a class="jxr_linenumber" name="L130" href="#L130">130</a> 
+<a class="jxr_linenumber" name="L131" href="#L131">131</a>     @Override
+<a class="jxr_linenumber" name="L132" href="#L132">132</a>     <strong class="jxr_keyword">public</strong> Optional&lt;File&gt; getJmodsFolder(<em class="jxr_comment">/* nullable */</em> File sourceJdkModules) {
+<a class="jxr_linenumber" name="L133" href="#L133">133</a>         <strong class="jxr_keyword">if</strong> (getToolchain().isPresent()) {
+<a class="jxr_linenumber" name="L134" href="#L134">134</a>             <strong class="jxr_keyword">return</strong> <strong class="jxr_keyword">super</strong>.getJmodsFolder(sourceJdkModules);
+<a class="jxr_linenumber" name="L135" href="#L135">135</a>         }
+<a class="jxr_linenumber" name="L136" href="#L136">136</a> 
+<a class="jxr_linenumber" name="L137" href="#L137">137</a>         <strong class="jxr_keyword">if</strong> (sourceJdkModules != <strong class="jxr_keyword">null</strong> &amp;&amp; sourceJdkModules.isDirectory()) {
+<a class="jxr_linenumber" name="L138" href="#L138">138</a>             <strong class="jxr_keyword">return</strong> Optional.of(<strong class="jxr_keyword">new</strong> File(sourceJdkModules, JMODS));
+<a class="jxr_linenumber" name="L139" href="#L139">139</a>         }
+<a class="jxr_linenumber" name="L140" href="#L140">140</a> 
+<a class="jxr_linenumber" name="L141" href="#L141">141</a>         <em class="jxr_comment">// ToolProvider does not need jmods folder to be set.</em>
+<a class="jxr_linenumber" name="L142" href="#L142">142</a>         <strong class="jxr_keyword">return</strong> Optional.empty();
+<a class="jxr_linenumber" name="L143" href="#L143">143</a>     }
+<a class="jxr_linenumber" name="L144" href="#L144">144</a> }
 </pre>
 <hr/>
-<div id="footer">Copyright &#169; 2016&#x2013;2020 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</div>
+<div id="footer">Copyright &#169; 2016&#x2013;2024 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</div>
 </body>
 </html>
\ No newline at end of file