------ Compiling Sources Using A Different JDK ------ Edwin Punzalan ------ 2006-07-05 ------ ~~ Licensed to the Apache Software Foundation (ASF) under one ~~ or more contributor license agreements. See the NOTICE file ~~ distributed with this work for additional information ~~ regarding copyright ownership. The ASF licenses this file ~~ to you 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. ~~ NOTE: For help with the syntax of this file, see: ~~ http://maven.apache.org/doxia/references/apt-format.html Compiling Sources Using A Different JDK * Using Maven Toolchains The preferable way to use a different JDK is to use the toolchains mechanism. During the build of a project, Maven, without toolchains, will use the JDK to perform various steps, like compiling the Java sources, generate the Javadoc, run unit tests or sign JARs. Each of those plugins need a tool of the JDK to operate: <<>>, <<>>, <<>>, etc. A toolchains is a way to specify the path to the JDK to use for all of those plugins in a centralized manner, independant from the one running Maven itself. To set this up, refer to the {{{/guides/mini/guide-using-toolchains.html}Guide to Using Toolchains}}, which makes use of the {{{/plugins/maven-toolchains-plugin/}Maven Toolchains Plugin}}. With the maven-toolchains-plugin you configure 1 default JDK toolchain for all related maven-plugins. Since maven-compiler-plugin 3.6.0 when using with Maven 3.3.1+ it is also possible to give the plugin its own toolchain, which can be useful in case of different JDK calls per execution block (e.g. the test sources require a different compiler compared to the main sources). * Configuring the Compiler Plugin Outside of a toolchains, it is still possible to tell the Compiler Plugin the specific JDK to use during compilation. Note that such configuration will be specific to this plugin, and will not affect others. The <<>> parameter can be used to specify the version of the compiler that the plugin will use. However, you also need to set <<>> to <<>> for this to work. For example: +------- [...] [...] org.apache.maven.plugins maven-compiler-plugin ${project.version} true true 1.3 [...] [...] +------- To avoid hard-coding a filesystem path for the executable, you can use a property. For example: +------- ${JAVA_1_4_HOME}/bin/javac +------- Each developer then defines this property in {{{http://maven.apache.org/ref/current/maven-settings/settings.html}settings.xml}}, or sets an environment variable, so that the build remains portable. +------- [...] [...] compiler C:\Program Files\Java\j2sdk1.4.2_09 [...] compiler +------- If you build with a different JDK, you may want to {{{http://maven.apache.org/plugins/maven-jar-plugin/examples/manifest-customization.html} customize}} the jar file manifest.