Skip to content

Commit

Permalink
šŸµšŸ¶šŸ»
Browse files Browse the repository at this point in the history
  • Loading branch information
alexsuter committed Jul 22, 2024
1 parent 1b9f88d commit 75e5e75
Show file tree
Hide file tree
Showing 9 changed files with 31 additions and 29 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ private void writeDependencyIarJar(Collection<File> iarJarDepenencies) throws IO
if (iarJarDepenencies == null) { // no dependencies
return;
}
var jar = new SharedFile(project).getIarDependencyClasspathJar().toFile();
var jar = new SharedFile(project).getIarDependencyClasspathJar();
new ClasspathJar(jar).createFileEntries(iarJarDepenencies);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package ch.ivyteam.ivy.maven.compile;

import java.io.File;
import java.nio.file.Files;
import java.util.Collections;
import java.util.List;
import java.util.Map;
Expand Down Expand Up @@ -60,8 +61,8 @@ protected void engineExec(MavenProjectBuilderProxy projectBuilder) throws Except
* @return persistent IAR-JARs from {@link CompileProjectMojo}.
*/
private List<File> getDependencyIarJars() {
var iarJarClasspath = new SharedFile(project).getIarDependencyClasspathJar().toFile();
if (!iarJarClasspath.exists()) {
var iarJarClasspath = new SharedFile(project).getIarDependencyClasspathJar();
if (!Files.exists(iarJarClasspath)) {
return Collections.emptyList();
}
List<File> iarJars = new ClasspathJar(iarJarClasspath).getFiles();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -130,8 +130,8 @@ public void writeEngineClasspathJar(File engineDirectory) throws IOException {
}

private void writeEngineClasspathJar(List<File> ivyEngineClassPathFiles) throws IOException {
var classPathJar = new SharedFile(maven.project).getEngineClasspathJar().toFile();
ClasspathJar jar = new ClasspathJar(classPathJar);
var classPathJar = new SharedFile(maven.project).getEngineClasspathJar();
var jar = new ClasspathJar(classPathJar);
jar.setMainClass("ch.ivyteam.ivy.server.ServerLauncher");
jar.createFileEntries(ivyEngineClassPathFiles);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,17 +58,17 @@ public EngineMojoContext(Path engineDirectory, MavenProject project, Log log, Pa
}

private String setupEngineClasspathJarIfNotExists() {
var classpathJar = new SharedFile(project).getEngineOSGiBootClasspathJar().toFile();
if (!classpathJar.exists()) {
var classpathJar = new SharedFile(project).getEngineOSGiBootClasspathJar();
if (!Files.exists(classpathJar)) {
try {
log.info("Creating a classpath jar for starting the engine");
new ClasspathJar(classpathJar)
.createFileEntries(EngineClassLoaderFactory.getOsgiBootstrapClasspath(engineDirectory));
} catch (Exception ex) {
throw new RuntimeException(
"Could not create engine classpath jar: '" + classpathJar.getAbsolutePath() + "'", ex);
"Could not create engine classpath jar: '" + classpathJar.toAbsolutePath() + "'", ex);
}
}
return classpathJar.getAbsolutePath();
return classpathJar.toAbsolutePath().toString();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.List;
Expand Down Expand Up @@ -89,13 +90,13 @@ public void execute() throws MojoExecutionException, MojoFailureException {

private void setIvyProperties(MavenProperties properties) throws MojoExecutionException {
SharedFile shared = new SharedFile(project);
var engineCp = shared.getEngineClasspathJar().toFile();
if (engineCp.exists()) {
var engineCp = shared.getEngineClasspathJar();
if (Files.exists(engineCp)) {
properties.setMavenProperty(Property.IVY_ENGINE_CLASSPATH, getClasspath(engineCp));
}

var iarCp = shared.getIarDependencyClasspathJar().toFile();
if (iarCp.exists()) {
var iarCp = shared.getIarDependencyClasspathJar();
if (Files.exists(iarCp)) {
properties.setMavenProperty(Property.IVY_PROJECT_IAR_CLASSPATH, getClasspath(iarCp));
}

Expand Down Expand Up @@ -151,8 +152,7 @@ private void setTestOutputDirectory() {
}
}

private static String getClasspath(File jar) {
private static String getClasspath(Path jar) {
return new ClasspathJar(jar).getClasspathFiles();
}

}
23 changes: 12 additions & 11 deletions src/main/java/ch/ivyteam/ivy/maven/util/ClasspathJar.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,12 @@

import java.io.EOFException;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
import java.net.URISyntaxException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
Expand All @@ -39,16 +39,17 @@

/**
* Jar with only a Manifest.MF that defines the classpath.
*
*
* @author Reguel Wermelinger
* @since 6.0.2
*/
public class ClasspathJar {

private static final String MANIFEST_MF = "META-INF/MANIFEST.MF";
private final File jar;
private final Path jar;
private String mainClass;

public ClasspathJar(File jar) {
public ClasspathJar(Path jar) {
this.jar = jar;
}

Expand All @@ -57,10 +58,10 @@ public void setMainClass(String fqClassName) {
}

public void create(List<String> classpathEntries) throws IOException {
jar.getParentFile().mkdir();
try (ZipOutputStream zipStream = new ZipOutputStream(new FileOutputStream(jar))) {
String name = StringUtils.substringBeforeLast(jar.getName(), ".");
writeManifest(name, zipStream, classpathEntries);
Files.createDirectories(jar.getParent());
try (var out = new ZipOutputStream(Files.newOutputStream(jar))) {
String name = StringUtils.substringBeforeLast(jar.getFileName().toString(), ".");
writeManifest(name, out, classpathEntries);
}
}

Expand Down Expand Up @@ -115,8 +116,8 @@ private static String uriToAbsoluteFilePath(String entry) {
}

public String getClasspathUrlEntries() {
try (ZipInputStream is = new ZipInputStream(new FileInputStream(jar))) {
Manifest manifest = new Manifest(getInputStream(is, MANIFEST_MF));
try (var in = new ZipInputStream(Files.newInputStream(jar))) {
Manifest manifest = new Manifest(getInputStream(in, MANIFEST_MF));
return manifest.getMainAttributes().getValue(Attributes.Name.CLASS_PATH);
} catch (IOException ex) {
return null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ protected void before() throws Throwable {
}

private void provideClasspathJar() throws IOException {
var cpJar = new SharedFile(project).getEngineOSGiBootClasspathJar().toFile();
var cpJar = new SharedFile(project).getEngineOSGiBootClasspathJar();
new ClasspathJar(cpJar).createFileEntries(EngineClassLoaderFactory
.getOsgiBootstrapClasspath(installUpToDateEngineRule.getMojo().getRawEngineDirectory().toPath()));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ class TestClasspathJar {
void readWriteClasspath() throws IOException {
var jarFile = tempDir.resolve("my.jar");
Files.createFile(jarFile);
ClasspathJar jar = new ClasspathJar(jarFile.toFile());
var jar = new ClasspathJar(jarFile);
var content = tempDir.resolve("content.jar");
Files.createFile(content);
jar.createFileEntries(List.of(content.toFile()));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ protected void before() throws Throwable {
}

private void writeTestClasspathJar() throws IOException {
var classPathJar = new SharedFile(getMojo().project).getEngineClasspathJar().toFile();
var classPathJar = new SharedFile(getMojo().project).getEngineClasspathJar();
new ClasspathJar(classPathJar).createFileEntries(Arrays.asList(
Files.createTempFile("dummy", ".jar").toFile(),
Files.createTempFile("dummy2", ".jar").toFile()));
Expand Down

0 comments on commit 75e5e75

Please sign in to comment.