From: Mathieu Baudier Date: Thu, 23 Mar 2023 13:32:27 +0000 (+0100) Subject: Fix external sources packaging X-Git-Tag: v2.3.5~3 X-Git-Url: https://git.argeo.org/?a=commitdiff_plain;h=3e76e38dbcf1964d1808fc74ff517a5a6251de82;p=cc0%2Fargeo-build.git Fix external sources packaging --- diff --git a/src/org/argeo/build/Make.java b/src/org/argeo/build/Make.java index b83404d..dde90a4 100644 --- a/src/org/argeo/build/Make.java +++ b/src/org/argeo/build/Make.java @@ -299,6 +299,7 @@ public class Make { } else { source = execDirectory.resolve(bundle); } + Path srcP = source.resolve("src"); Path compiled = buildBase.resolve(bundle); String bundleSymbolicName = source.getFileName().toString(); @@ -405,7 +406,6 @@ public class Make { } }); - Path srcP = source.resolve("src"); // Add all resources from src/ Files.walkFileTree(srcP, new SimpleFileVisitor() { @Override @@ -429,32 +429,33 @@ public class Make { // add sources // TODO add effective BND, Eclipse project file, etc., in order to be able to // repackage - if (sourceBundles) { - Path a2srcJarDirectory = bundleParent != null ? a2srcOutput.resolve(bundleParent).resolve(category) - : a2srcOutput.resolve(category); - Files.createDirectories(a2srcJarDirectory); - Path srcJarP = a2srcJarDirectory - .resolve(compiled.getFileName() + "." + major + "." + minor + ".src.jar"); - Manifest srcManifest = new Manifest(); - srcManifest.getMainAttributes().put(Attributes.Name.MANIFEST_VERSION, "1.0"); - srcManifest.getMainAttributes().putValue("Bundle-SymbolicName", bundleSymbolicName + ".src"); - srcManifest.getMainAttributes().putValue("Bundle-Version", - manifest.getMainAttributes().getValue("Bundle-Version").toString()); - srcManifest.getMainAttributes().putValue("Eclipse-SourceBundle", - bundleSymbolicName + ";version=\"" + manifest.getMainAttributes().getValue("Bundle-Version")); - - try (JarOutputStream srcJarOut = new JarOutputStream(Files.newOutputStream(srcJarP), srcManifest)) { - copySourcesToJar(srcP, srcJarOut, ""); - // add legal notices and licenses - for (Path p : listLegalFilesToInclude(source).values()) { - jarOut.putNextEntry(new JarEntry(p.getFileName().toString())); - Files.copy(p, jarOut); - } - } - } else { + if (!sourceBundles) { copySourcesToJar(srcP, jarOut, "OSGI-OPT/src/"); } } + + if (sourceBundles) {// create separate sources jar + Path a2srcJarDirectory = bundleParent != null ? a2srcOutput.resolve(bundleParent).resolve(category) + : a2srcOutput.resolve(category); + Files.createDirectories(a2srcJarDirectory); + Path srcJarP = a2srcJarDirectory.resolve(compiled.getFileName() + "." + major + "." + minor + ".src.jar"); + Manifest srcManifest = new Manifest(); + srcManifest.getMainAttributes().put(Attributes.Name.MANIFEST_VERSION, "1.0"); + srcManifest.getMainAttributes().putValue("Bundle-SymbolicName", bundleSymbolicName + ".src"); + srcManifest.getMainAttributes().putValue("Bundle-Version", + manifest.getMainAttributes().getValue("Bundle-Version").toString()); + srcManifest.getMainAttributes().putValue("Eclipse-SourceBundle", + bundleSymbolicName + ";version=\"" + manifest.getMainAttributes().getValue("Bundle-Version")); + + try (JarOutputStream srcJarOut = new JarOutputStream(Files.newOutputStream(srcJarP), srcManifest)) { + copySourcesToJar(srcP, srcJarOut, ""); + // add legal notices and licenses + for (Path p : listLegalFilesToInclude(source).values()) { + srcJarOut.putNextEntry(new JarEntry(p.getFileName().toString())); + Files.copy(p, srcJarOut); + } + } + } } /** List the relevant legal files to include, from the SDK source base. */