private final static String MERGE_BND = "merge.bnd";
private Path originBase;
+ private Path mavenBase;
+
private Path a2Base;
+ private Path a2SrcBase;
private Path a2LibBase;
private Path descriptorsBase;
private final boolean sourceBundles;
public Repackage(Path a2Base, Path descriptorsBase) {
- if (System.getenv(ENV_BUILD_SOURCE_BUNDLES) != null) {
- sourceBundles = Boolean.parseBoolean(System.getenv(ENV_BUILD_SOURCE_BUNDLES));
- if (sourceBundles)
- logger.log(Level.INFO, "Sources will be packaged separately");
- } else {
- sourceBundles = true;
- }
+ sourceBundles = Boolean.parseBoolean(System.getenv(ENV_BUILD_SOURCE_BUNDLES));
+ if (sourceBundles)
+ logger.log(Level.INFO, "Sources will be packaged separately");
Objects.requireNonNull(a2Base);
Objects.requireNonNull(descriptorsBase);
this.originBase = Paths.get(System.getProperty("user.home"), ".cache", "argeo/build/origin");
+ this.mavenBase = Paths.get(System.getProperty("user.home"), ".m2", "repository");
+
// TODO define and use a build base
this.a2Base = a2Base;
+ this.a2SrcBase = a2Base.getParent().resolve(a2Base.getFileName() + ".src");
this.a2LibBase = a2Base.resolve("lib");
this.descriptorsBase = descriptorsBase;
if (!Files.exists(this.descriptorsBase))
throw new IllegalArgumentException("No M2 coordinates available for " + bndFile);
M2Artifact artifact = new M2Artifact(m2Coordinates);
URL url = M2ConventionsUtils.mavenRepoUrl(repoStr, artifact);
- Path downloaded = downloadMaven(url, originBase, artifact);
+ Path downloaded = downloadMaven(url, artifact);
Path targetBundleDir = processBndJar(downloaded, targetCategoryBase, fileProps, artifact);
// download
URL url = M2ConventionsUtils.mavenRepoUrl(repoStr, artifact);
- Path downloaded = downloadMaven(url, originBase, artifact);
+ Path downloaded = downloadMaven(url, artifact);
Path targetBundleDir = processBndJar(downloaded, targetCategoryBase, mergeProps, artifact);
// logger.log(Level.DEBUG, () -> "Processed " + downloaded);
if (artifact.getVersion() == null)
artifact.setVersion(m2Version);
URL url = M2ConventionsUtils.mavenRepoUrl(repoStr, artifact);
- Path downloaded = downloadMaven(url, originBase, artifact);
+ Path downloaded = downloadMaven(url, artifact);
JarEntry entry;
try (JarInputStream jarIn = new JarInputStream(Files.newInputStream(downloaded), false)) {
entries: while ((entry = jarIn.getNextJarEntry()) != null) {
try {
M2Artifact sourcesArtifact = new M2Artifact(artifact.toM2Coordinates(), "sources");
URL sourcesUrl = M2ConventionsUtils.mavenRepoUrl(repoStr, sourcesArtifact);
- Path sourcesDownloaded = downloadMaven(sourcesUrl, originBase, artifact, true);
+ Path sourcesDownloaded = downloadMaven(sourcesUrl, artifact, true);
processM2SourceJar(sourcesDownloaded, targetBundleDir);
logger.log(Level.TRACE, () -> "Processed source " + sourcesDownloaded);
} catch (Exception e) {
}
/** Download a Maven artifact. */
- protected Path downloadMaven(URL url, Path dir, M2Artifact artifact) throws IOException {
- return downloadMaven(url, dir, artifact, false);
+ protected Path downloadMaven(URL url, M2Artifact artifact) throws IOException {
+ return downloadMaven(url, artifact, false);
}
/** Download a Maven artifact. */
- protected Path downloadMaven(URL url, Path dir, M2Artifact artifact, boolean sources) throws IOException {
- return download(url, dir, artifact.getGroupId() + '/' + artifact.getArtifactId() + "-" + artifact.getVersion()
- + (sources ? "-sources" : "") + ".jar");
+ protected Path downloadMaven(URL url, M2Artifact artifact, boolean sources) throws IOException {
+ return download(url, mavenBase, artifact.getGroupId().replace(".", "/") //
+ + '/' + artifact.getArtifactId() + '/' + artifact.getVersion() //
+ + '/' + artifact.getArtifactId() + "-" + artifact.getVersion() + (sources ? "-sources" : "") + ".jar");
}
/*
deleteDirectory(bundleDir);
if (sourceBundles) {
- Path sourceDir = bundleDir.getParent().resolve(bundleDir.toString() + ".src");
+ Path bundleCategoryDir = bundleDir.getParent();
+ Path sourceDir = bundleCategoryDir.resolve(bundleDir.toString() + ".src");
if (!Files.exists(sourceDir)) {
logger.log(WARNING, sourceDir + " does not exist, skipping...");
return jarPath;
+
}
- Path srcJarP = sourceDir.getParent().resolve(sourceDir.getFileName() + ".jar");
+
+ Path relPath = a2Base.relativize(bundleCategoryDir);
+ Path srcCategoryDir = a2SrcBase.resolve(relPath);
+ Path srcJarP = srcCategoryDir.resolve(sourceDir.getFileName() + ".jar");
+ Files.createDirectories(srcJarP.getParent());
+
String bundleSymbolicName = manifest.getMainAttributes().getValue("Bundle-SymbolicName").toString();
// in case there are additional directives
bundleSymbolicName = bundleSymbolicName.split(";")[0];