Added MANIFEST creation.
This commit is contained in:
parent
03bc4c3e9f
commit
d18b4e8ccb
2 changed files with 24 additions and 9 deletions
BIN
libs/fatjar-0.1.jar
(Stored with Git LFS)
BIN
libs/fatjar-0.1.jar
(Stored with Git LFS)
Binary file not shown.
|
@ -6,6 +6,7 @@ import java.util.*
|
||||||
import kotlin.system.measureTimeMillis
|
import kotlin.system.measureTimeMillis
|
||||||
|
|
||||||
internal var allFilesPredicate: ZipArchiveEntryPredicate = ZipArchiveEntryPredicate { true }
|
internal var allFilesPredicate: ZipArchiveEntryPredicate = ZipArchiveEntryPredicate { true }
|
||||||
|
internal val MANIFEST = "MANIFEST.MF"
|
||||||
|
|
||||||
fun main(args: Array<String>) {
|
fun main(args: Array<String>) {
|
||||||
val kobalt = File("kobalt-1.0.58.jar")
|
val kobalt = File("kobalt-1.0.58.jar")
|
||||||
|
@ -19,8 +20,7 @@ fun main(args: Array<String>) {
|
||||||
// Straight raw copy, not very flexible
|
// Straight raw copy, not very flexible
|
||||||
fun rezip(jarIn: File, zipOut: File) {
|
fun rezip(jarIn: File, zipOut: File) {
|
||||||
val time = measureTimeMillis {
|
val time = measureTimeMillis {
|
||||||
val zos = ZipArchiveOutputStream(zipOut)
|
val zos = ZipArchiveOutputStream(zipOut).apply { encoding = "UTF-8" }
|
||||||
zos.encoding = "UTF-8"
|
|
||||||
val zip = ZipFile(jarIn)
|
val zip = ZipFile(jarIn)
|
||||||
|
|
||||||
zip.copyRawEntries(zos, allFilesPredicate)
|
zip.copyRawEntries(zos, allFilesPredicate)
|
||||||
|
@ -35,8 +35,7 @@ fun rezip(jarIn: File, zipOut: File) {
|
||||||
// Raw copy: jar -> zip
|
// Raw copy: jar -> zip
|
||||||
fun rezip2(jarIn: File, zipOut: File) {
|
fun rezip2(jarIn: File, zipOut: File) {
|
||||||
val time = measureTimeMillis {
|
val time = measureTimeMillis {
|
||||||
val zos = ZipArchiveOutputStream(zipOut)
|
val zos = ZipArchiveOutputStream(zipOut).apply { encoding = "UTF-8" }
|
||||||
zos.encoding = "UTF-8"
|
|
||||||
val zip = ZipFile(jarIn)
|
val zip = ZipFile(jarIn)
|
||||||
|
|
||||||
for (entry in zip.entries) {
|
for (entry in zip.entries) {
|
||||||
|
@ -54,8 +53,7 @@ fun rezip2(jarIn: File, zipOut: File) {
|
||||||
// Raw copy: jar x 2 -> zip
|
// Raw copy: jar x 2 -> zip
|
||||||
fun rezip3(jarIn: File, srcJar: File, zipOut: File) {
|
fun rezip3(jarIn: File, srcJar: File, zipOut: File) {
|
||||||
val time = measureTimeMillis {
|
val time = measureTimeMillis {
|
||||||
val zos = ZipArchiveOutputStream(zipOut)
|
val zos = ZipArchiveOutputStream(zipOut).apply { encoding = "UTF-8" }
|
||||||
zos.encoding = "UTF-8"
|
|
||||||
val jar = ZipFile(jarIn)
|
val jar = ZipFile(jarIn)
|
||||||
|
|
||||||
// get the jar entries
|
// get the jar entries
|
||||||
|
@ -63,7 +61,9 @@ fun rezip3(jarIn: File, srcJar: File, zipOut: File) {
|
||||||
|
|
||||||
// copy the entries
|
// copy the entries
|
||||||
for (entry in jar.entries) {
|
for (entry in jar.entries) {
|
||||||
zos.addRawArchiveEntry(entry, jar.getRawInputStream(entry))
|
if (!entry.name.endsWith(MANIFEST)) {
|
||||||
|
zos.addRawArchiveEntry(entry, jar.getRawInputStream(entry))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
jar.close()
|
jar.close()
|
||||||
|
@ -78,6 +78,18 @@ fun rezip3(jarIn: File, srcJar: File, zipOut: File) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val tmp = File.createTempFile(MANIFEST, ".tmp")
|
||||||
|
tmp.bufferedWriter().use { out ->
|
||||||
|
out.write("Manifest-Version: 1.0\r\nMain-Class: com.beust.kobalt.MainKt\r\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
val entry = ZipArchiveEntry(tmp, "META-INF/$MANIFEST")
|
||||||
|
zos.putArchiveEntry(entry)
|
||||||
|
tmp.inputStream().use { ins ->
|
||||||
|
ins.copyTo(zos, 50 * 1024)
|
||||||
|
}
|
||||||
|
zos.closeArchiveEntry()
|
||||||
|
|
||||||
src.close()
|
src.close()
|
||||||
zos.close()
|
zos.close()
|
||||||
}
|
}
|
||||||
|
@ -88,6 +100,9 @@ fun rezip3(jarIn: File, srcJar: File, zipOut: File) {
|
||||||
// Look for duplicate entries
|
// Look for duplicate entries
|
||||||
fun entryExists(jarEntries: Enumeration<ZipArchiveEntry>, entry: ZipArchiveEntry): Boolean {
|
fun entryExists(jarEntries: Enumeration<ZipArchiveEntry>, entry: ZipArchiveEntry): Boolean {
|
||||||
for (e in jarEntries) {
|
for (e in jarEntries) {
|
||||||
|
if (e.name.endsWith(MANIFEST)) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
if (e.name == entry.name) {
|
if (e.name == entry.name) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue