commit
da753300a1
|
|
@ -60,6 +60,20 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
|
||||
private final Set<String> writtenEntries = new HashSet<>();
|
||||
|
||||
private Layers layers;
|
||||
|
||||
private LayersIndex layersIndex;
|
||||
|
||||
/**
|
||||
* Update this writer to use specific layers.
|
||||
* @param layers the layers to use
|
||||
* @param layersIndex the layers index to update
|
||||
*/
|
||||
void useLayers(Layers layers, LayersIndex layersIndex) {
|
||||
this.layers = layers;
|
||||
this.layersIndex = layersIndex;
|
||||
}
|
||||
|
||||
/**
|
||||
* Write the specified manifest.
|
||||
* @param manifest the manifest to write
|
||||
|
|
@ -89,7 +103,7 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
EntryWriter entryWriter = new InputStreamEntryWriter(inputStream);
|
||||
JarArchiveEntry transformedEntry = entryTransformer.transform(entry);
|
||||
if (transformedEntry != null) {
|
||||
writeEntry(transformedEntry, entryWriter, unpackHandler);
|
||||
writeEntry(transformedEntry, entryWriter, unpackHandler, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -144,7 +158,15 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
entry.setTime(getNestedLibraryTime(library));
|
||||
new CrcAndSize(library::openStream).setupStoredEntry(entry);
|
||||
try (InputStream inputStream = library.openStream()) {
|
||||
writeEntry(entry, new InputStreamEntryWriter(inputStream), new LibraryUnpackHandler(library));
|
||||
writeEntry(entry, new InputStreamEntryWriter(inputStream), new LibraryUnpackHandler(library), false);
|
||||
updateLayerIndex(entry.getName(), library);
|
||||
}
|
||||
}
|
||||
|
||||
private void updateLayerIndex(String name, Library library) {
|
||||
if (this.layers != null) {
|
||||
Layer layer = this.layers.getLayer(library);
|
||||
this.layersIndex.add(layer, name);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -225,7 +247,7 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
}
|
||||
|
||||
private void writeEntry(JarArchiveEntry entry, EntryWriter entryWriter) throws IOException {
|
||||
writeEntry(entry, entryWriter, UnpackHandler.NEVER);
|
||||
writeEntry(entry, entryWriter, UnpackHandler.NEVER, true);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -234,10 +256,11 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
* @param entry the entry to write
|
||||
* @param entryWriter the entry writer or {@code null} if there is no content
|
||||
* @param unpackHandler handles possible unpacking for the entry
|
||||
* @param updateLayerIndex if the layer index should be updated
|
||||
* @throws IOException in case of I/O errors
|
||||
*/
|
||||
private void writeEntry(JarArchiveEntry entry, EntryWriter entryWriter, UnpackHandler unpackHandler)
|
||||
throws IOException {
|
||||
private void writeEntry(JarArchiveEntry entry, EntryWriter entryWriter, UnpackHandler unpackHandler,
|
||||
boolean updateLayerIndex) throws IOException {
|
||||
String name = entry.getName();
|
||||
writeParentDirectoryEntries(name);
|
||||
if (this.writtenEntries.add(name)) {
|
||||
|
|
@ -248,10 +271,20 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
entry.setSize(entryWriter.size());
|
||||
}
|
||||
entryWriter = addUnpackCommentIfNecessary(entry, entryWriter, unpackHandler);
|
||||
if (updateLayerIndex) {
|
||||
updateLayerIndex(entry);
|
||||
}
|
||||
writeToArchive(entry, entryWriter);
|
||||
}
|
||||
}
|
||||
|
||||
private void updateLayerIndex(JarArchiveEntry entry) {
|
||||
if (this.layers != null && !entry.getName().endsWith("/")) {
|
||||
Layer layer = this.layers.getLayer(entry.getName());
|
||||
this.layersIndex.add(layer, entry.getName());
|
||||
}
|
||||
}
|
||||
|
||||
protected abstract void writeToArchive(ZipEntry entry, EntryWriter entryWriter) throws IOException;
|
||||
|
||||
private void writeParentDirectoryEntries(String name) throws IOException {
|
||||
|
|
@ -259,7 +292,7 @@ public abstract class AbstractJarWriter implements LoaderClassesWriter {
|
|||
while (parent.lastIndexOf('/') != -1) {
|
||||
parent = parent.substring(0, parent.lastIndexOf('/'));
|
||||
if (!parent.isEmpty()) {
|
||||
writeEntry(new JarArchiveEntry(parent + "/"), null, UnpackHandler.NEVER);
|
||||
writeEntry(new JarArchiveEntry(parent + "/"), null, UnpackHandler.NEVER, false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -29,7 +29,6 @@ import java.util.jar.Attributes;
|
|||
import java.util.jar.JarFile;
|
||||
import java.util.jar.Manifest;
|
||||
import java.util.stream.Collectors;
|
||||
import java.util.zip.ZipEntry;
|
||||
|
||||
import org.apache.commons.compress.archivers.jar.JarArchiveEntry;
|
||||
|
||||
|
|
@ -168,25 +167,18 @@ public abstract class Packager {
|
|||
protected final void write(JarFile sourceJar, Libraries libraries, AbstractJarWriter writer) throws IOException {
|
||||
Assert.notNull(libraries, "Libraries must not be null");
|
||||
WritableLibraries writeableLibraries = new WritableLibraries(libraries);
|
||||
if (isLayersEnabled()) {
|
||||
writer = new LayerTrackingEntryWriter(writer);
|
||||
if (isLayered()) {
|
||||
writer.useLayers(this.layers, this.layersIndex);
|
||||
}
|
||||
writer.writeManifest(buildManifest(sourceJar));
|
||||
writeLoaderClasses(writer);
|
||||
writer.writeEntries(sourceJar, getEntityTransformer(), writeableLibraries);
|
||||
writeableLibraries.write(writer);
|
||||
if (isLayersEnabled()) {
|
||||
if (isLayered()) {
|
||||
writeLayerIndex(writer);
|
||||
}
|
||||
}
|
||||
|
||||
private boolean isLayersEnabled() {
|
||||
if (!(getLayout() instanceof Layouts.Jar)) {
|
||||
return false;
|
||||
}
|
||||
return this.layers != null;
|
||||
}
|
||||
|
||||
private void writeLoaderClasses(AbstractJarWriter writer) throws IOException {
|
||||
Layout layout = getLayout();
|
||||
if (layout instanceof CustomLoaderLayout) {
|
||||
|
|
@ -339,7 +331,7 @@ public abstract class Packager {
|
|||
attributes.putValue(BOOT_CLASSES_ATTRIBUTE, layout.getRepackagedClassesLocation());
|
||||
putIfHasLength(attributes, BOOT_LIB_ATTRIBUTE, getLayout().getLibraryLocation("", LibraryScope.COMPILE));
|
||||
putIfHasLength(attributes, BOOT_CLASSPATH_INDEX_ATTRIBUTE, layout.getClasspathIndexFileLocation());
|
||||
if (isLayersEnabled()) {
|
||||
if (isLayered()) {
|
||||
putIfHasLength(attributes, BOOT_LAYERS_INDEX_ATTRIBUTE, layout.getLayersIndexFileLocation());
|
||||
}
|
||||
}
|
||||
|
|
@ -355,6 +347,10 @@ public abstract class Packager {
|
|||
}
|
||||
}
|
||||
|
||||
private boolean isLayered() {
|
||||
return this.layers != null && getLayout() instanceof Layouts.Jar;
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback interface used to present a warning when finding the main class takes too
|
||||
* long.
|
||||
|
|
@ -429,35 +425,6 @@ public abstract class Packager {
|
|||
|
||||
}
|
||||
|
||||
/**
|
||||
* Decorator to track the layers as entries are written.
|
||||
*/
|
||||
private final class LayerTrackingEntryWriter extends AbstractJarWriter {
|
||||
|
||||
private final AbstractJarWriter writer;
|
||||
|
||||
private LayerTrackingEntryWriter(AbstractJarWriter writer) {
|
||||
this.writer = writer;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeNestedLibrary(String location, Library library) throws IOException {
|
||||
this.writer.writeNestedLibrary(location, library);
|
||||
Layer layer = Packager.this.layers.getLayer(library);
|
||||
Packager.this.layersIndex.add(layer, location + library.getName());
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void writeToArchive(ZipEntry entry, EntryWriter entryWriter) throws IOException {
|
||||
this.writer.writeToArchive(entry, entryWriter);
|
||||
if (!entry.getName().endsWith("/")) {
|
||||
Layer layer = Packager.this.layers.getLayer(entry.getName());
|
||||
Packager.this.layersIndex.add(layer, entry.getName());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* An {@link UnpackHandler} that determines that an entry needs to be unpacked if a
|
||||
* library that requires unpacking has a matching entry name.
|
||||
|
|
@ -472,7 +439,7 @@ public abstract class Packager {
|
|||
addLibrary(library);
|
||||
}
|
||||
});
|
||||
if (isLayersEnabled() && Packager.this.includeRelevantJarModeJars) {
|
||||
if (isLayered() && Packager.this.includeRelevantJarModeJars) {
|
||||
addLibrary(JarModeLibrary.LAYER_TOOLS);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue