From c368f4c9f6635f7a2071881a70f940fac4f58d2d Mon Sep 17 00:00:00 2001 From: Matthew Cain Date: Sun, 14 Feb 2021 05:53:50 +0100 Subject: [PATCH] Improve zomboid class resolution --- .idea/runConfigurations/zomboidJar.xml | 23 ------------ zdoc.gradle | 2 +- zomboid.gradle | 51 ++++++++++---------------- 3 files changed, 21 insertions(+), 55 deletions(-) delete mode 100644 .idea/runConfigurations/zomboidJar.xml diff --git a/.idea/runConfigurations/zomboidJar.xml b/.idea/runConfigurations/zomboidJar.xml deleted file mode 100644 index 10b331b..0000000 --- a/.idea/runConfigurations/zomboidJar.xml +++ /dev/null @@ -1,23 +0,0 @@ - - - - - - - true - true - false - - - \ No newline at end of file diff --git a/zdoc.gradle b/zdoc.gradle index 32dfbb3..8f2b373 100644 --- a/zdoc.gradle +++ b/zdoc.gradle @@ -2,7 +2,7 @@ repositories { maven { url 'https://jitpack.io' } } configurations { - zomboidDoc + zomboidDoc.extendsFrom zomboidRuntimeOnly } dependencies { // https://github.com/real-coco-labs/pz-zdoc diff --git a/zomboid.gradle b/zomboid.gradle index 2070f49..c024d60 100644 --- a/zomboid.gradle +++ b/zomboid.gradle @@ -1,43 +1,32 @@ -import java.nio.file.Files -import java.nio.file.Path +// directory containing a copy of Project Zomboid classes +project.ext.zomboidClassesDir = file("$buildDir/classes/zomboid").absoluteFile + +/** + * This task will sync zomboidClassesDir with classes found in game install directory. + * Note that it needs to run before dependencies are declared so that + * the assembled classes can be included onto the classpath + */ +task zomboidClasses(type: Sync) { + description 'Assembles zomboid classes.' + group 'zomboid' + includeEmptyDirs false + from project.ext.gameDir + include '**/*.class', 'stdlib.lbc' + into zomboidClassesDir +} +classes.dependsOn(zomboidClasses) configurations { + runtimeOnly.extendsFrom zomboidRuntimeOnly implementation.extendsFrom zomboidImplementation } dependencies { // Project Zomboid libraries - zomboidImplementation fileTree(dir: gameDir, include: ['*.jar']) + zomboidRuntimeOnly fileTree(dir: gameDir, include: ['*.jar']) // Project Zomboid classes - zomboidImplementation files("lib/zomboid-$game_version" + '.jar') + zomboidImplementation files(zomboidClassesDir) } - -def zomboidJar = tasks.register("zomboidJar", Jar.class) { - it.onlyIf { - !project.ext.gameDir.empty - } - it.description('Assembles a jar archive containing game classes.') - it.setGroup('zomboid') - - it.archiveFileName = "zomboid-${game_version}.jar" - it.includeEmptyDirs = false - - it.from project.ext.gameDir - - HashSet excludePaths = new HashSet<>() - Files.walk(project.ext.gameDir as Path).withCloseable - { - it.filter({Files.isRegularFile(it) && !it.fileName.toString().endsWith('class') && it.fileName.toString() != "stdlib.lbc" - }).collect().forEach({ excludePaths.add(gameDir.relativize(it as Path).toString()) }) - } - it.setExcludes(excludePaths) - it.doLast { - //noinspection GroovyAssignabilityCheck - copyJarOutputToLib(it) - } -} -jar.dependsOn(zomboidJar) - /** * Decompile game classes with FernFlower using default IDEA settings. * Default task behaviour is to decompile all class files found in game root directory.