1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2024-12-14 20:20:30 +00:00

Avoid early creation of tasks

Notionally speeds up the build a little, though not really noticable in
practice.
This commit is contained in:
Jonathan Coates 2022-06-23 19:06:22 +01:00
parent 03f50f9298
commit 2d30208631
No known key found for this signature in database
GPG Key ID: B9E431FF07C98D06

View File

@ -2,7 +2,7 @@ plugins {
id "checkstyle" id "checkstyle"
id "jacoco" id "jacoco"
id "maven-publish" id "maven-publish"
id "com.github.hierynomus.license" version "0.16.1" id "org.cadixdev.licenser" version "0.6.1"
id "com.matthewprenger.cursegradle" version "1.4.0" id "com.matthewprenger.cursegradle" version "1.4.0"
id "com.github.breadmoirai.github-release" version "2.2.12" id "com.github.breadmoirai.github-release" version "2.2.12"
id "org.jetbrains.kotlin.jvm" version "1.7.0" id "org.jetbrains.kotlin.jvm" version "1.7.0"
@ -13,8 +13,6 @@ plugins {
id "com.github.johnrengelman.shadow" version "7.1.2" id "com.github.johnrengelman.shadow" version "7.1.2"
} }
import com.hierynomus.gradle.license.tasks.LicenseCheck
import com.hierynomus.gradle.license.tasks.LicenseFormat
import org.apache.tools.ant.taskdefs.condition.Os import org.apache.tools.ant.taskdefs.condition.Os
version = mod_version version = mod_version
@ -46,6 +44,7 @@ minecraft {
all { all {
property 'forge.logging.markers', 'REGISTRIES' property 'forge.logging.markers', 'REGISTRIES'
property 'forge.logging.console.level', 'debug' property 'forge.logging.console.level', 'debug'
forceExit = false
mods { mods {
computercraft { computercraft {
@ -85,6 +84,9 @@ minecraft {
workingDirectory project.file('test-files/server') workingDirectory project.file('test-files/server')
parent runs.server parent runs.server
property("cctest.run", "true")
property("forge.logging.console.level", "info")
mods { mods {
cctest { cctest {
source sourceSets.testMod source sourceSets.testMod
@ -152,15 +154,11 @@ dependencies {
// Compile tasks // Compile tasks
compileTestModJava {
dependsOn(compileJava)
}
javadoc { javadoc {
include "dan200/computercraft/api/**/*.java" include "dan200/computercraft/api/**/*.java"
} }
task apiJar(type: Jar) { def apiJar = tasks.register("apiJar", Jar.class) {
archiveClassifier.set("api") archiveClassifier.set("api")
from(sourceSets.main.output) { from(sourceSets.main.output) {
include "dan200/computercraft/api/**/*" include "dan200/computercraft/api/**/*"
@ -168,7 +166,7 @@ task apiJar(type: Jar) {
} }
assemble.dependsOn(apiJar) assemble.dependsOn(apiJar)
task luaJavadoc(type: Javadoc) { def luaJavadoc = tasks.register("luaJavadoc", Javadoc.class) {
description "Generates documentation for Java-side Lua functions." description "Generates documentation for Java-side Lua functions."
group "documentation" group "documentation"
@ -214,7 +212,11 @@ shadowJar {
assemble.dependsOn("shadowJar") assemble.dependsOn("shadowJar")
[compileJava, compileTestJava, compileTestModJava].forEach { [
tasks.named("compileJava", JavaCompile.class),
tasks.named("compileTestJava", JavaCompile.class),
tasks.named("compileTestModJava", JavaCompile.class)
].forEach {
it.configure { it.configure {
options.compilerArgs << "-Xlint" << "-Xlint:-processing" options.compilerArgs << "-Xlint" << "-Xlint:-processing"
} }
@ -287,7 +289,7 @@ List<String> mkCommand(String command) {
return Os.isFamily(Os.FAMILY_WINDOWS) ? ["cmd", "/c", command] : ["sh", "-c", command] return Os.isFamily(Os.FAMILY_WINDOWS) ? ["cmd", "/c", command] : ["sh", "-c", command]
} }
task rollup(type: Exec) { def rollup = tasks.register("rollup", Exec.class) {
group = "build" group = "build"
description = "Bundles JS into rollup" description = "Bundles JS into rollup"
@ -300,9 +302,10 @@ task rollup(type: Exec) {
commandLine mkCommand('"node_modules/.bin/rollup" --config rollup.config.js') commandLine mkCommand('"node_modules/.bin/rollup" --config rollup.config.js')
} }
task illuaminateDocs(type: Exec, dependsOn: [rollup, luaJavadoc]) { def illuaminateDocs = tasks.register("illuaminateDocs", Exec.class) {
group = "build" group = "documentation"
description = "Generates docs using Illuaminate" description = "Generates docs using Illuaminate"
dependsOn(rollup, luaJavadoc)
inputs.files(fileTree("doc")).withPropertyName("docs") inputs.files(fileTree("doc")).withPropertyName("docs")
inputs.files(fileTree("src/main/resources/data/computercraft/lua/rom")).withPropertyName("lua rom") inputs.files(fileTree("src/main/resources/data/computercraft/lua/rom")).withPropertyName("lua rom")
@ -315,9 +318,10 @@ task illuaminateDocs(type: Exec, dependsOn: [rollup, luaJavadoc]) {
commandLine mkCommand('"bin/illuaminate" doc-gen') commandLine mkCommand('"bin/illuaminate" doc-gen')
} }
task jsxDocs(type: Exec, dependsOn: [illuaminateDocs]) { def jsxDocs = tasks.register("jsxDocs", Exec) {
group = "build" group = "documentation"
description = "Post-processes documentation to statically render some dynamic content." description = "Post-processes documentation to statically render some dynamic content."
dependsOn(illuaminateDocs)
inputs.files(fileTree("src/web")).withPropertyName("sources") inputs.files(fileTree("src/web")).withPropertyName("sources")
inputs.file("src/generated/export/index.json").withPropertyName("export") inputs.file("src/generated/export/index.json").withPropertyName("export")
@ -329,7 +333,11 @@ task jsxDocs(type: Exec, dependsOn: [illuaminateDocs]) {
commandLine mkCommand('"node_modules/.bin/ts-node" --esm src/web/transform.tsx') commandLine mkCommand('"node_modules/.bin/ts-node" --esm src/web/transform.tsx')
} }
task docWebsite(type: Copy, dependsOn: [jsxDocs]) { def docWebsite = tasks.register("docWebsite", Copy.class) {
group = "documentation"
description = "Copy additional assets to the website directory."
dependsOn(jsxDocs)
from('doc') { from('doc') {
include 'logo.png' include 'logo.png'
include 'images/**' include 'images/**'
@ -364,48 +372,26 @@ jacocoTestReport {
} }
} }
test.finalizedBy(jacocoTestReport) test.finalizedBy("jacocoTestReport")
license { license {
mapping("java", "SLASHSTAR_STYLE") header = file('config/license/main.txt')
strictCheck true lineEnding = '\n'
newLine = false
ext.year = Calendar.getInstance().get(Calendar.YEAR) properties {
year = Calendar.getInstance().get(Calendar.YEAR)
} }
[licenseMain, licenseFormatMain].forEach { include("**/*.java") // We could apply to Kotlin, but for now let's not
it.configure { matching("dan200/computercraft/api/**") {
include("**/*.java") header = file('config/license/api.txt')
exclude("dan200/computercraft/api/**")
header file('config/license/main.txt')
} }
} }
[licenseTest, licenseFormatTest, licenseTestMod, licenseFormatTestMod].forEach { check.dependsOn("licenseCheck")
it.configure {
include("**/*.java")
header file('config/license/main.txt')
}
}
gradle.projectsEvaluated { def setupServer = tasks.register("setupServer", Copy.class) {
tasks.withType(LicenseFormat) {
outputs.upToDateWhen { false }
}
}
task licenseAPI(type: LicenseCheck)
task licenseFormatAPI(type: LicenseFormat)
[licenseAPI, licenseFormatAPI].forEach {
it.configure {
source = sourceSets.main.java
include("dan200/computercraft/api/**")
header file('config/license/api.txt')
}
}
task setupServer(type: Copy) {
group "test server" group "test server"
description "Sets up the environment for the test server." description "Sets up the environment for the test server."
@ -416,56 +402,55 @@ task setupServer(type: Copy) {
into "test-files/server" into "test-files/server"
} }
tasks.register("testServer", JavaExec.class).configure { def testServerClassDumpDir = new File(buildDir, "jacocoClassDump/runTestServer")
it.group('In-game tests')
it.description("Runs tests on a temporary Minecraft instance.") def testServer = tasks.register("testServer", JavaExec.class) {
it.dependsOn(setupServer, "prepareRunTestServer", "cleanTestServer", 'compileTestModJava') group("In-game tests")
description("Runs tests on a temporary Minecraft instance.")
dependsOn(setupServer, "cleanTestServer")
finalizedBy("jacocoTestServerReport") finalizedBy("jacocoTestServerReport")
// Copy from runTestServer. We do it in this slightly odd way as runTestServer // Copy from runTestServer. We do it in this slightly odd way as runTestServer
// isn't created until the task is configured (which is no good for us). // isn't created until the task is configured (which is no good for us).
JavaExec exec = tasks.getByName("runTestServer") JavaExec exec = tasks.getByName("runTestServer")
dependsOn(exec.getDependsOn())
exec.copyTo(it) exec.copyTo(it)
it.setClasspath(exec.getClasspath()) setClasspath(exec.getClasspath())
it.mainClass = exec.mainClass mainClass = exec.mainClass
it.setArgs(exec.getArgs()) setArgs(exec.getArgs())
it.systemProperty('forge.logging.console.level', 'info')
it.systemProperty('cctest.run', 'true')
// Jacoco and modlauncher don't play well together as the classes loaded in-game don't // Jacoco and modlauncher don't play well together as the classes loaded in-game don't
// match up with those written to disk. We get Jacoco to dump all classes to disk, and // match up with those written to disk. We get Jacoco to dump all classes to disk, and
// use that when generating the report. // use that when generating the report.
def coverageOut = new File(buildDir, "jacocoClassDump/testServer")
jacoco.applyTo(it) jacoco.applyTo(it)
it.jacoco.setIncludes(["dan200.computercraft.*"]) it.jacoco.setIncludes(["dan200.computercraft.*"])
it.jacoco.setClassDumpDir(coverageOut) it.jacoco.setClassDumpDir(testServerClassDumpDir)
it.outputs.dir(coverageOut) outputs.dir(testServerClassDumpDir)
// Older versions of modlauncher don't include a protection domain (and thus no code // Older versions of modlauncher don't include a protection domain (and thus no code
// source). Jacoco skips such classes by default, so we need to explicitly include them. // source). Jacoco skips such classes by default, so we need to explicitly include them.
it.jacoco.setIncludeNoLocationClasses(true) it.jacoco.setIncludeNoLocationClasses(true)
} }
tasks.register("jacocoTestServerReport", JacocoReport.class).configure { tasks.register("jacocoTestServerReport", JacocoReport.class) {
it.group('In-game') group("In-game tests")
it.description("Generate coverage reports for testServer") description("Generate coverage reports for testServer")
it.dependsOn("testServer") dependsOn(testServer)
it.executionData(new File(buildDir, "jacoco/testServer.exec")) executionData(new File(buildDir, "jacoco/testServer.exec"))
it.sourceDirectories.from(sourceSets.main.allJava.srcDirs) sourceDirectories.from(sourceSets.main.allJava.srcDirs)
it.classDirectories.from(new File(buildDir, "jacocoClassDump/testServer")) classDirectories.from(testServerClassDumpDir)
it.reports { reports {
xml.enabled true xml.enabled true
html.enabled true html.enabled true
} }
} }
check.dependsOn("testServer") check.dependsOn(testServer)
// Upload tasks // Upload tasks
task checkRelease { def checkRelease = tasks.register("checkRelease") {
group "upload" group "upload"
description "Verifies that everything is ready for a release" description "Verifies that everything is ready for a release"
@ -503,7 +488,7 @@ task checkRelease {
if (!ok) throw new IllegalStateException("Could not check release") if (!ok) throw new IllegalStateException("Could not check release")
} }
} }
check.dependsOn checkRelease check.dependsOn(checkRelease)
def isStable = true def isStable = true
@ -595,14 +580,14 @@ githubRelease {
.takeWhile { it != 'Type "help changelog" to see the full version history.' } .takeWhile { it != 'Type "help changelog" to see the full version history.' }
.join("\n").trim() .join("\n").trim()
})) }))
prerelease false
prerelease !isStable prerelease !isStable
} }
def uploadTasks = ["publish", "curseforge", "modrinth", "githubRelease"] def uploadTasks = ["publish", "curseforge", "modrinth", "githubRelease"]
uploadTasks.forEach { tasks.named(it) { dependsOn checkRelease } } uploadTasks.forEach { tasks.named(it) { dependsOn(checkRelease) } }
task uploadAll(dependsOn: uploadTasks) { tasks.register("uploadAll") {
group "upload" group = "upload"
description "Uploads to all repositories (Maven, Curse, Modrinth, GitHub release)" description = "Uploads to all repositories (Maven, Curse, Modrinth, GitHub release)"
dependsOn(uploadTasks)
} }