mirror of
https://github.com/architectury/architectury-loom.git
synced 2026-03-30 13:05:27 -05:00
Support Zip.getEntryCompression() setting (#936)
* Support Zip.getEntryCompression() setting * Checkstyle * Set for both the entry and ZOS
This commit is contained in:
@@ -53,6 +53,7 @@ import org.gradle.api.tasks.InputFiles;
|
||||
import org.gradle.api.tasks.Internal;
|
||||
import org.gradle.api.tasks.Optional;
|
||||
import org.gradle.api.tasks.SourceSet;
|
||||
import org.gradle.api.tasks.bundling.ZipEntryCompression;
|
||||
import org.gradle.build.event.BuildEventsListenerRegistry;
|
||||
import org.gradle.jvm.tasks.Jar;
|
||||
import org.gradle.workers.WorkAction;
|
||||
@@ -137,6 +138,7 @@ public abstract class AbstractRemapJarTask extends Jar {
|
||||
params.getArchiveReproducibleFileOrder().set(isReproducibleFileOrder());
|
||||
|
||||
params.getJarManifestService().set(jarManifestServiceProvider);
|
||||
params.getEntryCompression().set(getEntryCompression());
|
||||
|
||||
if (getIncludesClientOnlyClasses().get()) {
|
||||
final List<String> clientOnlyEntries = new ArrayList<>(getClientOnlyEntries(getClientSourceSet()));
|
||||
@@ -160,6 +162,7 @@ public abstract class AbstractRemapJarTask extends Jar {
|
||||
|
||||
Property<Boolean> getArchivePreserveFileTimestamps();
|
||||
Property<Boolean> getArchiveReproducibleFileOrder();
|
||||
Property<ZipEntryCompression> getEntryCompression();
|
||||
|
||||
Property<JarManifestService> getJarManifestService();
|
||||
MapProperty<String, String> getManifestAttributes();
|
||||
@@ -202,9 +205,10 @@ public abstract class AbstractRemapJarTask extends Jar {
|
||||
protected void rewriteJar() throws IOException {
|
||||
final boolean isReproducibleFileOrder = getParameters().getArchiveReproducibleFileOrder().get();
|
||||
final boolean isPreserveFileTimestamps = getParameters().getArchivePreserveFileTimestamps().get();
|
||||
final ZipEntryCompression compression = getParameters().getEntryCompression().get();
|
||||
|
||||
if (isReproducibleFileOrder || !isPreserveFileTimestamps) {
|
||||
ZipReprocessorUtil.reprocessZip(outputFile.toFile(), isReproducibleFileOrder, isPreserveFileTimestamps);
|
||||
if (isReproducibleFileOrder || !isPreserveFileTimestamps || compression != ZipEntryCompression.DEFLATED) {
|
||||
ZipReprocessorUtil.reprocessZip(outputFile.toFile(), isReproducibleFileOrder, isPreserveFileTimestamps, compression);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -38,6 +38,9 @@ import java.util.zip.ZipEntry;
|
||||
import java.util.zip.ZipFile;
|
||||
import java.util.zip.ZipOutputStream;
|
||||
|
||||
import org.gradle.api.tasks.bundling.ZipEntryCompression;
|
||||
import org.intellij.lang.annotations.MagicConstant;
|
||||
|
||||
public class ZipReprocessorUtil {
|
||||
/**
|
||||
* See {@link org.gradle.api.internal.file.archive.ZipCopyAction} about this.
|
||||
@@ -92,6 +95,10 @@ public class ZipReprocessorUtil {
|
||||
}
|
||||
|
||||
public static void reprocessZip(File file, boolean reproducibleFileOrder, boolean preserveFileTimestamps) throws IOException {
|
||||
reprocessZip(file, reproducibleFileOrder, preserveFileTimestamps, ZipEntryCompression.DEFLATED);
|
||||
}
|
||||
|
||||
public static void reprocessZip(File file, boolean reproducibleFileOrder, boolean preserveFileTimestamps, ZipEntryCompression zipEntryCompression) throws IOException {
|
||||
if (!reproducibleFileOrder && preserveFileTimestamps) {
|
||||
return;
|
||||
}
|
||||
@@ -111,6 +118,8 @@ public class ZipReprocessorUtil {
|
||||
final var outZip = new ByteArrayOutputStream(entries.length);
|
||||
|
||||
try (var zipOutputStream = new ZipOutputStream(outZip)) {
|
||||
zipOutputStream.setMethod(zipOutputStreamCompressionMethod(zipEntryCompression));
|
||||
|
||||
for (ZipEntry entry : entries) {
|
||||
ZipEntry newEntry = entry;
|
||||
|
||||
@@ -119,6 +128,7 @@ public class ZipReprocessorUtil {
|
||||
setConstantFileTime(newEntry);
|
||||
}
|
||||
|
||||
newEntry.setMethod(zipEntryCompressionMethod(zipEntryCompression));
|
||||
copyZipEntry(zipOutputStream, newEntry, zipFile.getInputStream(entry));
|
||||
}
|
||||
}
|
||||
@@ -177,4 +187,20 @@ public class ZipReprocessorUtil {
|
||||
entry.setLastModifiedTime(FileTime.fromMillis(ZipReprocessorUtil.CONSTANT_TIME_FOR_ZIP_ENTRIES));
|
||||
entry.setLastAccessTime(FileTime.fromMillis(ZipReprocessorUtil.CONSTANT_TIME_FOR_ZIP_ENTRIES));
|
||||
}
|
||||
|
||||
@MagicConstant(valuesFromClass = ZipOutputStream.class)
|
||||
private static int zipOutputStreamCompressionMethod(ZipEntryCompression compression) {
|
||||
return switch (compression) {
|
||||
case STORED -> ZipOutputStream.STORED;
|
||||
case DEFLATED -> ZipOutputStream.DEFLATED;
|
||||
};
|
||||
}
|
||||
|
||||
@MagicConstant(valuesFromClass = ZipEntry.class)
|
||||
private static int zipEntryCompressionMethod(ZipEntryCompression compression) {
|
||||
return switch (compression) {
|
||||
case STORED -> ZipEntry.STORED;
|
||||
case DEFLATED -> ZipEntry.DEFLATED;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user