From 10ea226d83dc5f9f64bed2958255c2f0ac4f496a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20L=C3=A4ubrich?= Date: Fri, 3 Nov 2023 13:19:34 +0100 Subject: [PATCH] Make additional P2 units from p2.inf available to the target-platform Currently units from p2.inf are not published to the target-platform what can fail resolving when these are referenced in the project. This publishes these units into the target-platform state of the project. Fix https://github.com/eclipse-tycho/tycho/issues/2977 --- .../p2resolver/TargetPlatformFactoryImpl.java | 29 ++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/tycho-core/src/main/java/org/eclipse/tycho/p2resolver/TargetPlatformFactoryImpl.java b/tycho-core/src/main/java/org/eclipse/tycho/p2resolver/TargetPlatformFactoryImpl.java index e1c02fe946..fb5298bcce 100644 --- a/tycho-core/src/main/java/org/eclipse/tycho/p2resolver/TargetPlatformFactoryImpl.java +++ b/tycho-core/src/main/java/org/eclipse/tycho/p2resolver/TargetPlatformFactoryImpl.java @@ -41,8 +41,8 @@ import org.codehaus.plexus.logging.Logger; import org.eclipse.core.runtime.IProgressMonitor; import org.eclipse.core.runtime.NullProgressMonitor; +import org.eclipse.core.runtime.Path; import org.eclipse.core.runtime.URIUtil; -import org.eclipse.equinox.internal.p2.artifact.repository.simple.SimpleArtifactDescriptor; import org.eclipse.equinox.p2.core.IProvisioningAgent; import org.eclipse.equinox.p2.core.ProvisionException; import org.eclipse.equinox.p2.metadata.IArtifactKey; @@ -50,7 +50,9 @@ import org.eclipse.equinox.p2.metadata.IProvidedCapability; import org.eclipse.equinox.p2.metadata.MetadataFactory; import org.eclipse.equinox.p2.metadata.MetadataFactory.InstallableUnitDescription; +import org.eclipse.equinox.p2.metadata.Version; import org.eclipse.equinox.p2.metadata.VersionRange; +import org.eclipse.equinox.p2.publisher.AdviceFileAdvice; import org.eclipse.equinox.p2.query.IQuery; import org.eclipse.equinox.p2.query.IQueryResult; import org.eclipse.equinox.p2.query.QueryUtil; @@ -68,6 +70,7 @@ import org.eclipse.tycho.IRepositoryIdManager; import org.eclipse.tycho.MavenArtifactKey; import org.eclipse.tycho.MavenRepositoryLocation; +import org.eclipse.tycho.PackagingType; import org.eclipse.tycho.ReactorProject; import org.eclipse.tycho.ReactorProjectIdentities; import org.eclipse.tycho.ResolvedArtifactKey; @@ -261,6 +264,8 @@ public P2TargetPlatform createTargetPlatform(TargetPlatformConfigurationStub tpC return Optional.empty(); }).ifPresent(externalUIs::add); } + //add p2.inf items... + gatherP2InfUnits(project, externalUIs); Map reactorProjectUIs = getPreliminaryReactorProjectUIs( reactorProjects); @@ -291,6 +296,28 @@ public P2TargetPlatform createTargetPlatform(TargetPlatformConfigurationStub tpC return targetPlatform; } + private void gatherP2InfUnits(ReactorProject reactorProject, Set externalUIs) { + AdviceFileAdvice advice; + if (PackagingType.TYPE_ECLIPSE_PLUGIN.equals(reactorProject.getPackaging())) { + advice = new AdviceFileAdvice(reactorProject.getArtifactId(), Version.parseVersion("1.0.0"), + new Path(reactorProject.getBasedir().getAbsolutePath()), AdviceFileAdvice.BUNDLE_ADVICE_FILE); + } else if (PackagingType.TYPE_ECLIPSE_FEATURE.equals(reactorProject.getPackaging())) { + advice = new AdviceFileAdvice(reactorProject.getArtifactId(), Version.parseVersion("1.0.0"), + new Path(reactorProject.getBasedir().getAbsolutePath()), new Path("p2.inf")); + } else { + //not a project with advice... + return; + } + if (advice.containsAdvice()) { + InstallableUnitDescription[] descriptions = advice.getAdditionalInstallableUnitDescriptions(null); + if (descriptions != null && descriptions.length > 0) { + for (InstallableUnitDescription desc : descriptions) { + externalUIs.add(MetadataFactory.createInstallableUnit(desc)); + } + } + } + } + private List getMissingJunitBundles(ReactorProject project, Set externalUIs) { List missing = new ArrayList<>(); if (projectManager != null) {