mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-24 16:07:01 +00:00
af21792844
We'll deploy this via a webhook instead.
155 lines
5.2 KiB
Plaintext
155 lines
5.2 KiB
Plaintext
// SPDX-FileCopyrightText: 2022 The CC: Tweaked Developers
|
|
//
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
import cc.tweaked.gradle.getAbsolutePath
|
|
|
|
plugins {
|
|
id("cc-tweaked.java-convention")
|
|
id("cc-tweaked.node")
|
|
id("cc-tweaked.illuaminate")
|
|
}
|
|
|
|
val modVersion: String by extra
|
|
|
|
node {
|
|
projectRoot.set(rootProject.projectDir)
|
|
}
|
|
|
|
illuaminate {
|
|
version.set(libs.versions.illuaminate)
|
|
}
|
|
|
|
sourceSets.register("builder")
|
|
|
|
dependencies {
|
|
implementation(project(":core"))
|
|
implementation(libs.bundles.teavm.api)
|
|
implementation(libs.asm)
|
|
implementation(libs.guava)
|
|
implementation(libs.netty.http)
|
|
implementation(libs.slf4j)
|
|
runtimeOnly(libs.teavm.core) // Contains the TeaVM runtime
|
|
|
|
"builderCompileOnly"(libs.bundles.annotations)
|
|
"builderImplementation"(libs.bundles.teavm.tooling)
|
|
"builderImplementation"(libs.asm)
|
|
"builderImplementation"(libs.asm.commons)
|
|
}
|
|
|
|
val compileTeaVM by tasks.registering(JavaExec::class) {
|
|
group = LifecycleBasePlugin.BUILD_GROUP
|
|
description = "Generate our classes and resources files"
|
|
|
|
val output = layout.buildDirectory.dir("teaVM")
|
|
val minify = !project.hasProperty("noMinify")
|
|
|
|
inputs.property("version", modVersion)
|
|
inputs.property("minify", minify)
|
|
inputs.files(sourceSets.main.get().runtimeClasspath).withPropertyName("inputClasspath")
|
|
outputs.dir(output).withPropertyName("output")
|
|
|
|
classpath = sourceSets["builder"].runtimeClasspath
|
|
jvmArguments.addAll(
|
|
provider {
|
|
val main = sourceSets.main.get()
|
|
listOf(
|
|
"-Dcct.input=${main.output.classesDirs.asPath}",
|
|
"-Dcct.version=$modVersion",
|
|
"-Dcct.classpath=${main.runtimeClasspath.asPath}",
|
|
"-Dcct.output=${output.getAbsolutePath()}",
|
|
"-Dcct.minify=$minify",
|
|
)
|
|
},
|
|
)
|
|
mainClass.set("cc.tweaked.web.builder.Builder")
|
|
javaLauncher.set(project.javaToolchains.launcherFor { languageVersion.set(java.toolchain.languageVersion) })
|
|
}
|
|
|
|
val rollup by tasks.registering(cc.tweaked.gradle.NpxExecToDir::class) {
|
|
group = LifecycleBasePlugin.BUILD_GROUP
|
|
description = "Bundles JS into rollup"
|
|
|
|
val minify = !project.hasProperty("noMinify")
|
|
inputs.property("minify", minify)
|
|
|
|
// Sources
|
|
inputs.files(fileTree("src/frontend")).withPropertyName("sources")
|
|
inputs.files(compileTeaVM)
|
|
// Config files
|
|
inputs.file("tsconfig.json").withPropertyName("Typescript config")
|
|
inputs.file("rollup.config.js").withPropertyName("Rollup config")
|
|
|
|
// Output directory. Also defined in illuaminate.sexp and rollup.config.js
|
|
output.set(layout.buildDirectory.dir("rollup"))
|
|
|
|
args = listOf("rollup", "--config", "rollup.config.js") + if (minify) emptyList() else listOf("--configDebug")
|
|
}
|
|
|
|
val illuaminateDocs by tasks.registering(cc.tweaked.gradle.IlluaminateExecToDir::class) {
|
|
group = JavaBasePlugin.DOCUMENTATION_GROUP
|
|
description = "Generates docs using Illuaminate"
|
|
|
|
// Config files
|
|
inputs.file(rootProject.file("illuaminate.sexp")).withPropertyName("illuaminate config")
|
|
// Sources
|
|
inputs.files(rootProject.fileTree("doc")).withPropertyName("docs")
|
|
inputs.files(project(":core").fileTree("src/main/resources/data/computercraft/lua")).withPropertyName("lua rom")
|
|
inputs.files(project(":common").tasks.named("luaJavadoc"))
|
|
// Assets
|
|
inputs.files(rollup)
|
|
|
|
// Output directory. Also defined in illuaminate.sexp.
|
|
output.set(layout.buildDirectory.dir("illuaminate"))
|
|
|
|
args = listOf("doc-gen")
|
|
workingDir = rootProject.projectDir
|
|
}
|
|
|
|
val htmlTransform by tasks.registering(cc.tweaked.gradle.NpxExecToDir::class) {
|
|
group = JavaBasePlugin.DOCUMENTATION_GROUP
|
|
description = "Post-processes documentation to statically render some dynamic content."
|
|
|
|
val sources = fileTree("src/htmlTransform")
|
|
|
|
// Config files
|
|
inputs.file("tsconfig.json").withPropertyName("Typescript config")
|
|
// Sources
|
|
inputs.files(sources).withPropertyName("sources")
|
|
inputs.files(illuaminateDocs)
|
|
|
|
// Output directory.
|
|
output.set(layout.buildDirectory.dir(name))
|
|
|
|
argumentProviders.add {
|
|
listOf(
|
|
"tsx",
|
|
sources.dir.resolve("index.tsx").absolutePath,
|
|
illuaminateDocs.get().output.getAbsolutePath(),
|
|
sources.dir.resolve("export/index.json").absolutePath,
|
|
output.getAbsolutePath(),
|
|
)
|
|
}
|
|
}
|
|
|
|
val docWebsite by tasks.registering(Copy::class) {
|
|
group = JavaBasePlugin.DOCUMENTATION_GROUP
|
|
description = "Assemble docs and assets together into the documentation website."
|
|
duplicatesStrategy = DuplicatesStrategy.FAIL
|
|
|
|
from(htmlTransform)
|
|
|
|
// index.js is provided by illuaminate, but rollup outputs some other chunks
|
|
from(rollup) { exclude("index.js") }
|
|
// Grab illuaminate's assets. HTML files are provided by jsxDocs
|
|
from(illuaminateDocs) { exclude("**/*.html") }
|
|
// And item/block images from the data export
|
|
from(file("src/htmlTransform/export/items")) { into("images/items") }
|
|
// Add the common-api (and core-api) javadoc
|
|
from(project(":common-api").tasks.named("javadoc")) { into("javadoc") }
|
|
|
|
into(layout.buildDirectory.dir("site"))
|
|
}
|
|
|
|
tasks.assemble { dependsOn(docWebsite) }
|