From acb6e63b7d675d6d664cf855c9683a04bff14a7c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20L=C3=A4ubrich?= Date: Sun, 14 Apr 2024 18:09:54 +0200 Subject: [PATCH] Fix NPE in MavenChecksumAdvice (cherry picked from commit b110909834cc796cf8fc9fdc206b40771b71d152) --- .../p2maven/advices/MavenChecksumAdvice.java | 79 ++++++++++--------- 1 file changed, 41 insertions(+), 38 deletions(-) diff --git a/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/advices/MavenChecksumAdvice.java b/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/advices/MavenChecksumAdvice.java index 23f18179d6..f607bf5b3e 100644 --- a/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/advices/MavenChecksumAdvice.java +++ b/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/advices/MavenChecksumAdvice.java @@ -27,48 +27,51 @@ import org.eclipse.equinox.p2.repository.artifact.spi.ArtifactDescriptor; public class MavenChecksumAdvice implements IPropertyAdvice { - //We use a fixed list here of default supported ones, actually one can provide a ChecksumAlgorithmFactory to extend the default algorithms - Map mavenExtensions = Map.of(// - ".md5", "download.checksum.md5", // - ".sha1", "download.checksum.sha-1", // - ".sha256", "download.checksum.sha-256", // - ".sha512", "download.checksum.sha-512" // - ); + // We use a fixed list here of default supported ones, actually one can provide + // a ChecksumAlgorithmFactory to extend the default algorithms + Map mavenExtensions = Map.of(// + ".md5", "download.checksum.md5", // + ".sha1", "download.checksum.sha-1", // + ".sha256", "download.checksum.sha-256", // + ".sha512", "download.checksum.sha-512" // + ); - private File artifactFile; + private File artifactFile; - public MavenChecksumAdvice(File artifactFile) { - this.artifactFile = artifactFile; - } + public MavenChecksumAdvice(File artifactFile) { + this.artifactFile = artifactFile; + } - @Override - public Map getInstallableUnitProperties(InstallableUnitDescription iu) { - return Collections.emptyMap(); - } + @Override + public Map getInstallableUnitProperties(InstallableUnitDescription iu) { + return Collections.emptyMap(); + } - @Override - public Map getArtifactProperties(IInstallableUnit iu, IArtifactDescriptor descriptor) { - if (descriptor instanceof ArtifactDescriptor artifactDescriptor) { - // Workaround bug Bug 539672 - String baseName = artifactFile.getName(); - for (var entry : mavenExtensions.entrySet()) { - File file = new File(artifactFile.getParentFile(), baseName + entry.getKey()); - if (file.isFile()) { - try { - String checksum = Files.readString(file.toPath(), StandardCharsets.US_ASCII).strip(); - artifactDescriptor.setProperty(entry.getValue(), checksum); - } catch (IOException e) { - //can't use the checksum then... - } - } - } - } - return null; - } + @Override + public Map getArtifactProperties(IInstallableUnit iu, IArtifactDescriptor descriptor) { + if (artifactFile != null) { + if (descriptor instanceof ArtifactDescriptor artifactDescriptor) { + // Workaround bug Bug 539672 + String baseName = artifactFile.getName(); + for (var entry : mavenExtensions.entrySet()) { + File file = new File(artifactFile.getParentFile(), baseName + entry.getKey()); + if (file.isFile()) { + try { + String checksum = Files.readString(file.toPath(), StandardCharsets.US_ASCII).strip(); + artifactDescriptor.setProperty(entry.getValue(), checksum); + } catch (IOException e) { + // can't use the checksum then... + } + } + } + } + } + return null; + } - @Override - public boolean isApplicable(String configSpec, boolean includeDefault, String id, Version version) { - return true; - } + @Override + public boolean isApplicable(String configSpec, boolean includeDefault, String id, Version version) { + return true; + } }