1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2024-11-05 09:36:19 +00:00
CC-Tweaked/projects/web/build.gradle.kts
Jonathan Coates 84a799d27a
Add abstract classes for our generic peripherals
This commit adds abstract classes to describe the interface for our
mod-loader-specific generic peripherals (inventories, fluid storage,
item storage).

This offers several advantages:
 - Javadoc to illuaminate conversion no longer needs the Forge project
   (just core and common).

 - Ensures we have a consistent interface between Forge and Fabric.

Note, this does /not/ implement fluid or energy storage for Fabric. We
probably could do fluid without issue, but not something worth doing
right now.
2023-11-22 18:20:15 +00:00

157 lines
5.1 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)
"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)
// Pick up assets from the /docs folder
from(rootProject.file("doc")) {
include("logo.png")
include("images/**")
}
// 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") }
into(layout.buildDirectory.dir("site"))
}
tasks.assemble { dependsOn(docWebsite) }