diff --git a/RELEASE_NOTES.md b/RELEASE_NOTES.md
index 55cd186ed1..f9ea79cb7a 100644
--- a/RELEASE_NOTES.md
+++ b/RELEASE_NOTES.md
@@ -6,6 +6,22 @@ If you are reading this in the browser, then you can quickly jump to specific ve
## 5.0.0 (under development)
+### using javac as the compiler for Tycho
+
+You can now use `javac` as the compiler backend for Tycho by adding the following configuration:
+
+```xml
+
+ org.eclipse.tycho
+ tycho-compiler-plugin
+ ${tycho.version}
+
+ javac
+
+
+ ```
+
+
### new `mirror-target-platform`
There is a new `mirror-target-platform` that allows to mirror the current target platform of a project into a P2 update site, this can b enabled for a project like this:
diff --git a/tycho-compiler-plugin/pom.xml b/tycho-compiler-plugin/pom.xml
index c99d3203ca..70cff57273 100644
--- a/tycho-compiler-plugin/pom.xml
+++ b/tycho-compiler-plugin/pom.xml
@@ -87,6 +87,11 @@
bcel
test
+
+ org.codehaus.plexus
+ plexus-compiler-javac
+ 2.14.2
+
diff --git a/tycho-compiler-plugin/src/main/java/copied/org/apache/maven/plugin/AbstractCompilerMojo.java b/tycho-compiler-plugin/src/main/java/copied/org/apache/maven/plugin/AbstractCompilerMojo.java
index 37f94ae550..b3daec6d0c 100644
--- a/tycho-compiler-plugin/src/main/java/copied/org/apache/maven/plugin/AbstractCompilerMojo.java
+++ b/tycho-compiler-plugin/src/main/java/copied/org/apache/maven/plugin/AbstractCompilerMojo.java
@@ -57,6 +57,8 @@
*/
public abstract class AbstractCompilerMojo extends AbstractMojo {
+ protected static final String JDT_COMPILER_ID = "jdt";
+
public static final String DEFAULT_SOURCE_VERSION = "11";
public static final String DEFAULT_TARGET_VERSION = "11";
@@ -144,8 +146,8 @@ public abstract class AbstractCompilerMojo extends AbstractMojo {
/**
* The compiler id of the compiler to use.
*/
- @Parameter(property = "maven.compiler.compilerId", defaultValue = "jdt")
- private String compilerId;
+ @Parameter(property = "maven.compiler.compilerId", defaultValue = JDT_COMPILER_ID)
+ protected String compilerId;
/**
* Version of the compiler to use, ex. "1.3", "1.5", if fork is set to true
diff --git a/tycho-compiler-plugin/src/main/java/org/eclipse/tycho/compiler/AbstractOsgiCompilerMojo.java b/tycho-compiler-plugin/src/main/java/org/eclipse/tycho/compiler/AbstractOsgiCompilerMojo.java
index e052d7cc59..5551f78b79 100644
--- a/tycho-compiler-plugin/src/main/java/org/eclipse/tycho/compiler/AbstractOsgiCompilerMojo.java
+++ b/tycho-compiler-plugin/src/main/java/org/eclipse/tycho/compiler/AbstractOsgiCompilerMojo.java
@@ -573,6 +573,7 @@ public List getClasspathElements() throws MojoExecutionException {
final List classpath = new ArrayList<>();
Set seen = new HashSet<>();
Set includedPathes = new HashSet<>();
+ boolean useAccessRules = JDT_COMPILER_ID.equals(compilerId);
for (ClasspathEntry cpe : getClasspath()) {
Stream classpathLocations = Stream
.concat(cpe.getLocations().stream(),
@@ -581,7 +582,7 @@ public List getClasspathElements() throws MojoExecutionException {
.filter(AbstractOsgiCompilerMojo::isValidLocation).distinct();
classpathLocations.forEach(location -> {
String path = location.getAbsolutePath();
- String entry = path + toString(cpe.getAccessRules());
+ String entry = path + toString(cpe.getAccessRules(), useAccessRules);
if (seen.add(entry)) {
includedPathes.add(path);
classpath.add(entry);
@@ -646,19 +647,22 @@ protected BundleProject getBundleProject() throws MojoExecutionException {
return (BundleProject) projectType;
}
- private String toString(Collection rules) {
- StringJoiner result = new StringJoiner(RULE_SEPARATOR, "[", "]"); // include all
- if (rules != null) {
- for (AccessRule rule : rules) {
- result.add((rule.isDiscouraged() ? "~" : "+") + rule.getPattern());
+ private String toString(Collection rules, boolean useAccessRules) {
+ if (useAccessRules) {
+ StringJoiner result = new StringJoiner(RULE_SEPARATOR, "[", "]"); // include all
+ if (rules != null) {
+ for (AccessRule rule : rules) {
+ result.add((rule.isDiscouraged() ? "~" : "+") + rule.getPattern());
+ }
+ result.add(RULE_EXCLUDE_ALL);
+ } else {
+ // include everything, not strictly necessary, but lets make this obvious
+ //result.append("[+**/*]");
+ return "";
}
- result.add(RULE_EXCLUDE_ALL);
- } else {
- // include everything, not strictly necessary, but lets make this obvious
- //result.append("[+**/*]");
- return "";
+ return result.toString();
}
- return result.toString();
+ return "";
}
@Override
@@ -719,7 +723,7 @@ protected CompilerConfiguration getCompilerConfiguration(List compileSou
List> copy = new ArrayList<>(
compilerConfiguration.getCustomCompilerArgumentsEntries());
compilerConfiguration.getCustomCompilerArgumentsEntries().clear();
- compilerConfiguration.addCompilerCustomArgument("-properties", prefsFilePath);
+ addCompilerCustomArgument(compilerConfiguration, "-properties", prefsFilePath);
compilerConfiguration.getCustomCompilerArgumentsEntries().addAll(copy);
}
}
@@ -738,7 +742,7 @@ protected CompilerConfiguration getCompilerConfiguration(List compileSou
if (jreClasspathEntry.isModule()) {
Collection modules = jreClasspathEntry.getLimitModules();
if (!modules.isEmpty()) {
- compilerConfiguration.addCompilerCustomArgument("--limit-modules", String.join(",", modules));
+ addCompilerCustomArgument(compilerConfiguration, "--limit-modules", String.join(",", modules));
}
}
}
@@ -782,7 +786,7 @@ private void configureCompilerLog(CompilerConfiguration compilerConfiguration) t
fileExtension = "log";
}
logPath = logPath + logFileName + "." + fileExtension;
- compilerConfiguration.addCompilerCustomArgument("-log", logPath);
+ addCompilerCustomArgument(compilerConfiguration, "-log", logPath);
}
private void configureBootclasspathAccessRules(CompilerConfiguration compilerConfiguration)
@@ -811,8 +815,8 @@ private void configureBootclasspathAccessRules(CompilerConfiguration compilerCon
.addAll(getBundleProject().getBootClasspathExtraAccessRules(DefaultReactorProject.adapt(project)));
}
if (!accessRules.isEmpty()) {
- compilerConfiguration.addCompilerCustomArgument("org.osgi.framework.system.packages",
- toString(accessRules));
+ addCompilerCustomArgument(compilerConfiguration, "org.osgi.framework.system.packages",
+ toString(accessRules, true));
}
}
@@ -837,7 +841,7 @@ private void configureJavaHome(CompilerConfiguration compilerConfiguration) thro
.orElseThrow(() -> new MojoExecutionException(
"useJDK = BREE configured, but no toolchain of type 'jdk' with id '" + toolchainId
+ "' found. See https://maven.apache.org/guides/mini/guide-using-toolchains.html"));
- compilerConfiguration.addCompilerCustomArgument("use.java.home", osgiToolchain.getJavaHome());
+ addCompilerCustomArgument(compilerConfiguration, "use.java.home", osgiToolchain.getJavaHome());
configureBootClassPath(compilerConfiguration, osgiToolchain);
}
}
@@ -851,7 +855,7 @@ private void configureBootClassPath(CompilerConfiguration compilerConfiguration,
if (includeParent != null) {
Xpp3Dom[] includes = includeParent.getChildren("include");
if (includes.length > 0) {
- compilerConfiguration.addCompilerCustomArgument("-bootclasspath", scanBootclasspath(
+ addCompilerCustomArgument(compilerConfiguration, "-bootclasspath", scanBootclasspath(
osgiToolchain.getJavaHome(), includes, bootClassPath.getChild("excludes")));
}
}
@@ -859,6 +863,14 @@ private void configureBootClassPath(CompilerConfiguration compilerConfiguration,
}
}
+ protected boolean addCompilerCustomArgument(CompilerConfiguration compilerConfiguration, String key, String value) {
+ if (JDT_COMPILER_ID.equals(compilerId)) {
+ compilerConfiguration.addCompilerCustomArgument(key, value);
+ return true;
+ }
+ return false;
+ }
+
private String scanBootclasspath(String javaHome, Xpp3Dom[] includes, Xpp3Dom excludeParent) {
DirectoryScanner scanner = new DirectoryScanner();
scanner.setBasedir(javaHome);
diff --git a/tycho-its/projects/tycho-compiler-plugin/javac/pom.xml b/tycho-its/projects/tycho-compiler-plugin/javac/pom.xml
new file mode 100644
index 0000000000..c6de9f2183
--- /dev/null
+++ b/tycho-its/projects/tycho-compiler-plugin/javac/pom.xml
@@ -0,0 +1,36 @@
+
+ 4.0.0
+
+ org.eclipse.tycho.it
+ javac.parent
+ 1.0.0-SNAPSHOT
+ pom
+
+ 5.0.0-SNAPSHOT
+
+
+
+
+
+ org.eclipse.tycho
+ tycho-maven-plugin
+ ${tycho-version}
+ true
+
+
+ org.eclipse.tycho
+ tycho-compiler-plugin
+ ${tycho-version}
+
+ javac
+
+
+
+
+
+
+ simple
+
+
diff --git a/tycho-its/projects/tycho-compiler-plugin/javac/simple/META-INF/MANIFEST.MF b/tycho-its/projects/tycho-compiler-plugin/javac/simple/META-INF/MANIFEST.MF
new file mode 100644
index 0000000000..ac88e3c0dc
--- /dev/null
+++ b/tycho-its/projects/tycho-compiler-plugin/javac/simple/META-INF/MANIFEST.MF
@@ -0,0 +1,4 @@
+Manifest-Version: 1.0
+Bundle-ManifestVersion: 2
+Bundle-SymbolicName: simple
+Bundle-Version: 1.0.0.qualifier
diff --git a/tycho-its/projects/tycho-compiler-plugin/javac/simple/build.properties b/tycho-its/projects/tycho-compiler-plugin/javac/simple/build.properties
new file mode 100644
index 0000000000..34d2e4d2da
--- /dev/null
+++ b/tycho-its/projects/tycho-compiler-plugin/javac/simple/build.properties
@@ -0,0 +1,4 @@
+source.. = src/
+output.. = bin/
+bin.includes = META-INF/,\
+ .
diff --git a/tycho-its/projects/tycho-compiler-plugin/javac/simple/pom.xml b/tycho-its/projects/tycho-compiler-plugin/javac/simple/pom.xml
new file mode 100644
index 0000000000..89b6ed014a
--- /dev/null
+++ b/tycho-its/projects/tycho-compiler-plugin/javac/simple/pom.xml
@@ -0,0 +1,13 @@
+
+ 4.0.0
+
+ org.eclipse.tycho.it
+ javac.parent
+ 1.0.0-SNAPSHOT
+
+ simple
+
+ eclipse-plugin
+
+
\ No newline at end of file
diff --git a/tycho-its/projects/tycho-compiler-plugin/javac/simple/src/Test.java b/tycho-its/projects/tycho-compiler-plugin/javac/simple/src/Test.java
new file mode 100644
index 0000000000..461755c786
--- /dev/null
+++ b/tycho-its/projects/tycho-compiler-plugin/javac/simple/src/Test.java
@@ -0,0 +1,19 @@
+/*******************************************************************************
+ * Copyright (c) 2012 SAP AG and others.
+ * This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License 2.0
+ * which accompanies this distribution, and is available at
+ * https://www.eclipse.org/legal/epl-2.0/
+ *
+ * SPDX-License-Identifier: EPL-2.0
+ *
+ * Contributors:
+ * SAP AG - initial API and implementation
+ *******************************************************************************/
+
+public class Test
+{
+ public static void main(String[] args) {
+ int a = 0;
+ }
+}
diff --git a/tycho-its/src/test/java/org/eclipse/tycho/test/CompilerPluginTest.java b/tycho-its/src/test/java/org/eclipse/tycho/test/CompilerPluginTest.java
new file mode 100644
index 0000000000..fedcd0cce0
--- /dev/null
+++ b/tycho-its/src/test/java/org/eclipse/tycho/test/CompilerPluginTest.java
@@ -0,0 +1,30 @@
+/*******************************************************************************
+ * Copyright (c) 2024 Christoph Läubrich and others.
+ * This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License 2.0
+ * which accompanies this distribution, and is available at
+ * https://www.eclipse.org/legal/epl-2.0/
+ *
+ * SPDX-License-Identifier: EPL-2.0
+ *
+ * Contributors:
+ * Christoph Läubrich - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.tycho.test;
+
+import org.apache.maven.it.Verifier;
+import org.junit.Test;
+
+/**
+ * Test for the tycho-compiler-plugin
+ */
+public class CompilerPluginTest extends AbstractTychoIntegrationTest {
+
+ @Test
+ public void testJavac() throws Exception {
+ Verifier verifier = getVerifier("tycho-compiler-plugin/javac", true, true);
+ verifier.executeGoal("compile");
+ verifier.verifyErrorFreeLog();
+ }
+
+}