Finalized packr update
This commit is contained in:
@@ -1,7 +1,4 @@
|
||||
import com.badlogicgames.packr.Packr
|
||||
import com.badlogicgames.packr.PackrConfig
|
||||
|
||||
sourceSets.main.java.srcDirs = [ "src/" ]
|
||||
sourceSets.main.java.srcDirs = ["src/" ]
|
||||
|
||||
project.ext.mainClassName = "mindustry.desktop.DesktopLauncher"
|
||||
project.ext.assetsDir = new File("../core/assets")
|
||||
@@ -9,6 +6,7 @@ project.ext.assetsDir = new File("../core/assets")
|
||||
def enableTemplates = true
|
||||
def JDK_DIR = "$System.env.JDK_DIR"
|
||||
def ICON_DIR = new File("$rootDir/core/assets/icons/icon.icns")
|
||||
def platforms = ["Linux64", "Windows64", "Windows32", "MacOS"]
|
||||
|
||||
task run(dependsOn: classes, type: JavaExec){
|
||||
main = project.mainClassName
|
||||
@@ -36,7 +34,6 @@ task run(dependsOn: classes, type: JavaExec){
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
task dist(type: Jar, dependsOn: configurations.runtimeClasspath){
|
||||
from files(sourceSets.main.output.classesDirs)
|
||||
from files(sourceSets.main.output.resourcesDir)
|
||||
@@ -74,11 +71,11 @@ task steamtest(dependsOn: dist){
|
||||
|
||||
//required templates:
|
||||
//- Windows64
|
||||
//- Windows32 (not provided by Packr!)
|
||||
//required JDKs:
|
||||
//- Windows32
|
||||
//- Linux64
|
||||
//- Mac
|
||||
PackrConfig.Platform.values().each{ platform ->
|
||||
platforms.each{ platform ->
|
||||
task "packr${platform.toString()}"{
|
||||
dependsOn dist
|
||||
|
||||
@@ -93,7 +90,8 @@ PackrConfig.Platform.values().each{ platform ->
|
||||
delete "build/packr/output/"
|
||||
}
|
||||
|
||||
if(enableTemplates && (platform == PackrConfig.Platform.Windows64)){
|
||||
//the Windows32 version uses an old java-8 based template, because packr and jpackage don't support win32
|
||||
if(enableTemplates && (platform == "Windows32")){
|
||||
copy{
|
||||
into "build/packr/output"
|
||||
from "${JDK_DIR}/templates/${platform.toString().toLowerCase()}"
|
||||
@@ -105,30 +103,35 @@ PackrConfig.Platform.values().each{ platform ->
|
||||
from "build/libs/${appName}.jar"
|
||||
}
|
||||
}else{
|
||||
def config = new PackrConfig()
|
||||
config.with{
|
||||
//TODO consider useZgcIfSupportedOs = true
|
||||
config.executable = appName
|
||||
config.platform = platform
|
||||
verbose = true
|
||||
bundleIdentifier = getPackage() + ".mac"
|
||||
iconResource = ICON_DIR
|
||||
outDir = file("$rootDir/desktop/build/packr/output")
|
||||
mainClass = project.ext.mainClassName
|
||||
classpath = ["$rootDir/desktop/build/packr/desktop.jar".toString()]
|
||||
removePlatformLibs = ["$rootDir/desktop/build/packr/desktop.jar".toString()]
|
||||
def jarPath = JDK_DIR + "packr.jar"
|
||||
def args = ["java", "-jar", jarPath] as String[]
|
||||
|
||||
vmArgs = ["XX:+ShowCodeDetailsInExceptionMessages"]
|
||||
jdk = JDK_DIR + "jdk-${platform.toString().toLowerCase()}.zip"
|
||||
args += [
|
||||
"--platform", platform == "MacOS" ? "Mac" : platform.toString(),
|
||||
"--jdk", JDK_DIR + "jre-${platform.toString().toLowerCase()}",
|
||||
"--executable", appName,
|
||||
"--classpath", "$rootDir/desktop/build/packr/desktop.jar".toString(),
|
||||
"--mainclass", project.ext.mainClassName,
|
||||
"--verbose",
|
||||
"--bundle", getPackage() + ".mac",
|
||||
"--icon", ICON_DIR,
|
||||
"--output", "$rootDir/desktop/build/packr/output".toString(),
|
||||
"--removelibs", "$rootDir/desktop/build/packr/desktop.jar".toString()
|
||||
]
|
||||
|
||||
if(platform == PackrConfig.Platform.MacOS){
|
||||
vmArgs += "XstartOnFirstThread"
|
||||
}
|
||||
if(platform == "MacOS"){
|
||||
args += ["--vmargs", "XstartOnFirstThread"] as String[]
|
||||
}else{
|
||||
//TODO unneeded for windows?
|
||||
args += ["--vmargs", "Dhttps.protocols=TLSv1.2,TLSv1.1,TLSv1"]
|
||||
}
|
||||
|
||||
new Packr().pack(config)
|
||||
exec{
|
||||
commandLine args.toList()
|
||||
standardOutput = System.out
|
||||
}
|
||||
|
||||
if(platform != PackrConfig.Platform.MacOS){
|
||||
if(platform != "MacOS"){
|
||||
copy{
|
||||
into "build/packr/output/jre/"
|
||||
from "build/packr/output/desktop.jar"
|
||||
@@ -138,10 +141,8 @@ PackrConfig.Platform.values().each{ platform ->
|
||||
delete "build/packr/output/desktop.jar"
|
||||
}
|
||||
|
||||
file("build/packr/output/config.json").text = file("build/packr/output/config.json").text.replace("desktop.jar", "jre/desktop.jar")
|
||||
}
|
||||
|
||||
if(platform == PackrConfig.Platform.MacOS){
|
||||
file("build/packr/output/Mindustry.json").text = file("build/packr/output/Mindustry.json").text.replace("desktop.jar", "jre/desktop.jar")
|
||||
}else{
|
||||
copy{
|
||||
into "build/packr/output/${appName}.app/Contents/"
|
||||
from "build/packr/output/Contents/"
|
||||
@@ -153,7 +154,7 @@ PackrConfig.Platform.values().each{ platform ->
|
||||
}
|
||||
}
|
||||
|
||||
if((platform == PackrConfig.Platform.Windows64 || platform == PackrConfig.Platform.Windows32)){
|
||||
if((platform == "Windows64" || platform == "Windows32")){
|
||||
copy{
|
||||
from "build/packr/output/jre/bin/msvcr100.dll"
|
||||
into "build/packr/output/"
|
||||
@@ -163,12 +164,12 @@ PackrConfig.Platform.values().each{ platform ->
|
||||
|
||||
if(versionModifier.contains("steam")){
|
||||
copy{
|
||||
def lib = platform == PackrConfig.Platform.MacOS || platform == PackrConfig.Platform.Linux64 ? "lib" : ""
|
||||
from zipTree(platform == PackrConfig.Platform.MacOS ? "build/packr/output/${appName}.app/Contents/Resources/desktop.jar" : "build/packr/output/jre/desktop.jar").matching{
|
||||
include "${lib}steamworks4j${platform == PackrConfig.Platform.Windows64 ? '64.dll' : platform == PackrConfig.Platform.Windows32 ? '.dll' : platform == PackrConfig.Platform.Linux64 ? '.so' : '.dylib'}"
|
||||
include "${lib}steam_api${platform == PackrConfig.Platform.Windows64 ? '64.dll' : platform == PackrConfig.Platform.Windows32 ? '.dll' : platform == PackrConfig.Platform.Linux64 ? '.so' : '.dylib'}"
|
||||
def lib = platform == "MacOS" || platform == "Linux64" ? "lib" : ""
|
||||
from zipTree(platform == "MacOS" ? "build/packr/output/${appName}.app/Contents/Resources/desktop.jar" : "build/packr/output/jre/desktop.jar").matching{
|
||||
include "${lib}steamworks4j${platform == "Windows64" ? '64.dll' : platform == "Windows32" ? '.dll' : platform == "Linux64" ? '.so' : '.dylib'}"
|
||||
include "${lib}steam_api${platform == "Windows64" ? '64.dll' : platform == "Windows32" ? '.dll' : platform == "Linux64" ? '.so' : '.dylib'}"
|
||||
}
|
||||
into platform != PackrConfig.Platform.MacOS ? "build/packr/output/" : "build/packr/output/${appName}.app/Contents/Resources"
|
||||
into platform != "MacOS" ? "build/packr/output/" : "build/packr/output/${appName}.app/Contents/Resources"
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user