From d7a9363601eaa8148af6d67cc89b7af0e67a3f78 Mon Sep 17 00:00:00 2001 From: Patrick Ziegler Date: Sat, 9 Dec 2023 10:36:26 +0100 Subject: [PATCH] Skip target bundles with invalid manifest during IU generation #996 A call to BundlesAction.createBundleDescription() returns null, if the manifest of the current bundle contains invalid headers (e.g. the same package is imported twice). If left unchecked, this causes an unhandled NullPointerException a few lines further down. Add an explicit null, in order to simply skip this invalid bundle. --- .../core/target/InstallableUnitGenerator.java | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/ui/org.eclipse.pde.core/src/org/eclipse/pde/internal/core/target/InstallableUnitGenerator.java b/ui/org.eclipse.pde.core/src/org/eclipse/pde/internal/core/target/InstallableUnitGenerator.java index b697af7715..959a6824ec 100644 --- a/ui/org.eclipse.pde.core/src/org/eclipse/pde/internal/core/target/InstallableUnitGenerator.java +++ b/ui/org.eclipse.pde.core/src/org/eclipse/pde/internal/core/target/InstallableUnitGenerator.java @@ -81,11 +81,14 @@ public static Stream generateInstallableUnits(TargetBundle tar PublisherInfo publisherInfo = new PublisherInfo(); publisherInfo.setArtifactOptions(IPublisherInfo.A_INDEX); BundleDescription bundleDescription = BundlesAction.createBundleDescription(headers, null); - IInstallableUnit iu = BundlesAction.createBundleIU(bundleDescription, - BundlesAction.createBundleArtifactKey(bundleDescription.getSymbolicName(), - bundleDescription.getVersion().toString()), - publisherInfo); - return Stream.of(iu); + // null if bundle contains invalid manifest headers + if (bundleDescription != null) { + IInstallableUnit iu = BundlesAction.createBundleIU(bundleDescription, + BundlesAction.createBundleArtifactKey(bundleDescription.getSymbolicName(), + bundleDescription.getVersion().toString()), + publisherInfo); + return Stream.of(iu); + } } catch (IOException e) { // can't use it then... }