diff --git a/tycho-api/src/main/java/org/eclipse/tycho/TargetEnvironment.java b/tycho-api/src/main/java/org/eclipse/tycho/TargetEnvironment.java
index d5e2a81384..8c03b971a3 100644
--- a/tycho-api/src/main/java/org/eclipse/tycho/TargetEnvironment.java
+++ b/tycho-api/src/main/java/org/eclipse/tycho/TargetEnvironment.java
@@ -21,6 +21,7 @@
import org.eclipse.equinox.internal.p2.metadata.InstallableUnit;
import org.eclipse.equinox.p2.metadata.IInstallableUnit;
import org.eclipse.equinox.p2.metadata.expression.IMatchExpression;
+import org.osgi.framework.Filter;
public final class TargetEnvironment {
private static final Properties EMPTY_PROPERTIES = new Properties();
@@ -70,6 +71,13 @@ public boolean match(String os, String ws, String arch) {
(arch == null || arch.equals(this.arch));
}
+ public boolean match(Filter filter) {
+ if (filter != null) {
+ return filter.matches(toFilterProperties());
+ }
+ return true;
+ }
+
/**
* Returns the target environment as string of the form ws.os.arch
. This format is
* used by the p2 publishers and in that context called "configuration" or "config spec".
diff --git a/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiAnalysisMojo.java b/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiAnalysisMojo.java
index bf67f52071..f6f711ba68 100644
--- a/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiAnalysisMojo.java
+++ b/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiAnalysisMojo.java
@@ -45,6 +45,7 @@
import org.eclipse.tycho.DependencyResolutionException;
import org.eclipse.tycho.IllegalArtifactReferenceException;
import org.eclipse.tycho.MavenRepositoryLocation;
+import org.eclipse.tycho.TargetEnvironment;
import org.eclipse.tycho.TychoConstants;
import org.eclipse.tycho.core.TychoProjectManager;
import org.eclipse.tycho.core.osgitools.DefaultReactorProject;
@@ -134,9 +135,6 @@ public class ApiAnalysisMojo extends AbstractMojo {
@Component
private TychoProjectManager projectManager;
- @Component
- private ApiApplicationResolver resolver;
-
@Component
private ApiApplicationResolver applicationResolver;
@@ -145,8 +143,8 @@ public void execute() throws MojoExecutionException, MojoFailureException {
if (skip) {
return;
}
- Optional eclipseProject = projectManager.getEclipseProject(project);
- if (eclipseProject.isEmpty() || !eclipseProject.get().hasNature(ApiPlugin.NATURE_ID)) {
+ Optional eclipseProjectValue = projectManager.getEclipseProject(project);
+ if (eclipseProjectValue.isEmpty() || !eclipseProjectValue.get().hasNature(ApiPlugin.NATURE_ID)) {
return;
}
@@ -293,12 +291,14 @@ private Collection getBaselineBundles() throws MojoFailureException {
long start = System.currentTimeMillis();
Collection baselineBundles;
try {
+ Collection targetEnvironments = projectManager.getTargetEnvironments(project);
Optional artifactKey = projectManager.getArtifactKey(project);
- getLog().info("Resolve API baseline for " + project.getId());
- baselineBundles = resolver.getApiBaselineBundles(
+ getLog().info("Resolve API baseline for " + project.getId() + " with "
+ + targetEnvironments.stream().map(String::valueOf).collect(Collectors.joining(", ")));
+ baselineBundles = applicationResolver.getApiBaselineBundles(
baselines.stream().filter(repo -> repo.getUrl() != null)
.map(repo -> new MavenRepositoryLocation(repo.getId(), URI.create(repo.getUrl()))).toList(),
- artifactKey.get());
+ artifactKey.get(), targetEnvironments);
getLog().debug("API baseline contains " + baselineBundles.size() + " bundles (resolve takes " + time(start)
+ ").");
} catch (IllegalArtifactReferenceException e) {
diff --git a/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiApplicationResolver.java b/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiApplicationResolver.java
index 57cf919f2b..b0034964db 100644
--- a/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiApplicationResolver.java
+++ b/tycho-apitools-plugin/src/main/java/org/eclipse/tycho/apitools/ApiApplicationResolver.java
@@ -28,6 +28,7 @@
import org.eclipse.tycho.ArtifactType;
import org.eclipse.tycho.IllegalArtifactReferenceException;
import org.eclipse.tycho.MavenRepositoryLocation;
+import org.eclipse.tycho.TargetEnvironment;
import org.eclipse.tycho.TargetPlatform;
import org.eclipse.tycho.core.resolver.P2ResolutionResult;
import org.eclipse.tycho.core.resolver.P2ResolutionResult.Entry;
@@ -59,8 +60,9 @@ public class ApiApplicationResolver {
private EclipseApplicationManager applicationManager;
public Collection getApiBaselineBundles(Collection baselineRepoLocations,
- ArtifactKey artifactKey) throws IllegalArtifactReferenceException {
- P2Resolver resolver = applicationFactory.createResolver();
+ ArtifactKey artifactKey, Collection environment)
+ throws IllegalArtifactReferenceException {
+ P2Resolver resolver = applicationFactory.createResolver(environment);
resolver.addDependency(ArtifactType.TYPE_INSTALLABLE_UNIT, artifactKey.getId(), "0.0.0");
List resolvedBundles = new ArrayList<>();
TargetPlatform targetPlatform = applicationFactory.createTargetPlatform(baselineRepoLocations);
diff --git a/tycho-core/src/main/java/org/eclipse/tycho/core/TychoProjectManager.java b/tycho-core/src/main/java/org/eclipse/tycho/core/TychoProjectManager.java
index 0565d42e79..3bc1f79f47 100644
--- a/tycho-core/src/main/java/org/eclipse/tycho/core/TychoProjectManager.java
+++ b/tycho-core/src/main/java/org/eclipse/tycho/core/TychoProjectManager.java
@@ -62,6 +62,7 @@
import org.eclipse.tycho.helper.PluginRealmHelper;
import org.eclipse.tycho.model.project.EclipseProject;
import org.eclipse.tycho.targetplatform.TargetDefinition;
+import org.osgi.framework.Filter;
import aQute.bnd.osgi.Processor;
@@ -176,6 +177,16 @@ public TargetPlatformConfiguration getTargetPlatformConfiguration(ReactorProject
return getTargetPlatformConfiguration(project.adapt(MavenProject.class));
}
+ public Collection getTargetEnvironments(MavenProject project) {
+ TychoProject tychoProject = projectTypes.get(project.getPackaging());
+ if (tychoProject != null) {
+ Filter environmentFilter = tychoProject.getTargetEnvironmentFilter(project);
+ return getTargetPlatformConfiguration(project).getEnvironments().stream()
+ .filter(te -> te.match(environmentFilter)).toList();
+ }
+ return List.of(TargetEnvironment.getRunningEnvironment());
+ }
+
public Optional getTychoProject(MavenProject project) {
if (project == null) {
return Optional.empty();
diff --git a/tycho-core/src/main/java/org/eclipse/tycho/core/resolver/DefaultTargetPlatformConfigurationReader.java b/tycho-core/src/main/java/org/eclipse/tycho/core/resolver/DefaultTargetPlatformConfigurationReader.java
index c9cd9d6863..cdfff6cb0b 100644
--- a/tycho-core/src/main/java/org/eclipse/tycho/core/resolver/DefaultTargetPlatformConfigurationReader.java
+++ b/tycho-core/src/main/java/org/eclipse/tycho/core/resolver/DefaultTargetPlatformConfigurationReader.java
@@ -375,10 +375,10 @@ private void addTargetEnvironments(TargetPlatformConfiguration result, MavenProj
List skipped = new ArrayList<>();
for (Xpp3Dom environmentDom : environmentsDom.getChildren("environment")) {
TargetEnvironment environment = newTargetEnvironment(environmentDom);
- if (!matchFilter(environment, filter)) {
- skipped.add(environment);
- } else {
+ if (environment.match(filter)) {
result.addEnvironment(environment);
+ } else {
+ skipped.add(environment);
}
}
if (!skipped.isEmpty()) {
@@ -394,13 +394,6 @@ private void addTargetEnvironments(TargetPlatformConfiguration result, MavenProj
}
}
- private static boolean matchFilter(TargetEnvironment environment, Filter filter) {
- if (filter != null) {
- return filter.matches(environment.toFilterProperties());
- }
- return true;
- }
-
private static Filter getTargetEnvironmentFilter(TychoProject tychoProject, MavenProject project) {
if (tychoProject != null) {
return tychoProject.getTargetEnvironmentFilter(project);
diff --git a/tycho-core/src/main/java/org/eclipse/tycho/osgi/framework/EclipseApplicationFactory.java b/tycho-core/src/main/java/org/eclipse/tycho/osgi/framework/EclipseApplicationFactory.java
index 1cc18105ed..f0d893eb14 100644
--- a/tycho-core/src/main/java/org/eclipse/tycho/osgi/framework/EclipseApplicationFactory.java
+++ b/tycho-core/src/main/java/org/eclipse/tycho/osgi/framework/EclipseApplicationFactory.java
@@ -13,7 +13,6 @@
package org.eclipse.tycho.osgi.framework;
import java.util.Collection;
-import java.util.Collections;
import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors;
@@ -97,8 +96,11 @@ public TargetPlatform createTargetPlatform(Collection l
}
public P2Resolver createResolver() {
- P2Resolver resolver = resolverFactory
- .createResolver(Collections.singletonList(TargetEnvironment.getRunningEnvironment()));
+ return createResolver(List.of(TargetEnvironment.getRunningEnvironment()));
+ }
+
+ public P2Resolver createResolver(Collection environments) {
+ P2Resolver resolver = resolverFactory.createResolver(environments);
return resolver;
}