mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-07 07:50:27 +00:00
Various improvements to packaging
This fixes several issues I had with consuming multi-loader CC:T in various upstream mods. - Include /all/ sources in the Forge/Fabric jar. Before it was just the common classes, and not the core or API. - Use some Gradle magic to remove superfluous dependencies from the POM file. Also make sure Cobalt and Netty are present as dependencies. - Start using minimize() in our shadow jar config again.
This commit is contained in:
parent
8152f19b6e
commit
8d2e150f05
@ -2,10 +2,38 @@ import org.jetbrains.gradle.ext.compiler
|
|||||||
import org.jetbrains.gradle.ext.settings
|
import org.jetbrains.gradle.ext.settings
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
|
publishing
|
||||||
alias(libs.plugins.taskTree)
|
alias(libs.plugins.taskTree)
|
||||||
|
alias(libs.plugins.githubRelease)
|
||||||
id("org.jetbrains.gradle.plugin.idea-ext")
|
id("org.jetbrains.gradle.plugin.idea-ext")
|
||||||
|
id("cc-tweaked")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val isUnstable = project.properties["isUnstable"] == "true"
|
||||||
|
val modVersion: String by extra
|
||||||
|
val mcVersion: String by extra
|
||||||
|
|
||||||
|
githubRelease {
|
||||||
|
token(findProperty("githubApiKey") as String? ?: "")
|
||||||
|
owner.set("cc-tweaked")
|
||||||
|
repo.set("CC-Tweaked")
|
||||||
|
targetCommitish.set(cct.gitBranch)
|
||||||
|
|
||||||
|
tagName.set("v$mcVersion-$modVersion")
|
||||||
|
releaseName.set("[$mcVersion] $modVersion")
|
||||||
|
body.set(
|
||||||
|
provider {
|
||||||
|
"## " + project(":core").file("src/main/resources/data/computercraft/lua/rom/help/whatsnew.md")
|
||||||
|
.readLines()
|
||||||
|
.takeWhile { it != "Type \"help changelog\" to see the full version history." }
|
||||||
|
.joinToString("\n").trim()
|
||||||
|
},
|
||||||
|
)
|
||||||
|
prerelease.set(isUnstable)
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.publish { dependsOn(tasks.githubRelease) }
|
||||||
|
|
||||||
idea.project.settings.compiler.javac {
|
idea.project.settings.compiler.javac {
|
||||||
// We want ErrorProne to be present when compiling via IntelliJ, as it offers some helpful warnings
|
// We want ErrorProne to be present when compiling via IntelliJ, as it offers some helpful warnings
|
||||||
// and errors. Loop through our source sets and find the appropriate flags.
|
// and errors. Loop through our source sets and find the appropriate flags.
|
||||||
|
@ -3,11 +3,6 @@ plugins {
|
|||||||
`kotlin-dsl`
|
`kotlin-dsl`
|
||||||
}
|
}
|
||||||
|
|
||||||
repositories {
|
|
||||||
mavenCentral()
|
|
||||||
gradlePluginPortal()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Duplicated in settings.gradle.kts
|
// Duplicated in settings.gradle.kts
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import cc.tweaked.gradle.CCTweakedExtension
|
||||||
import cc.tweaked.gradle.CCTweakedPlugin
|
import cc.tweaked.gradle.CCTweakedPlugin
|
||||||
import cc.tweaked.gradle.LicenseHeader
|
import cc.tweaked.gradle.LicenseHeader
|
||||||
import com.diffplug.gradle.spotless.FormatExtension
|
import com.diffplug.gradle.spotless.FormatExtension
|
||||||
@ -21,10 +22,7 @@ val mcVersion: String by extra
|
|||||||
group = "cc.tweaked"
|
group = "cc.tweaked"
|
||||||
version = modVersion
|
version = modVersion
|
||||||
|
|
||||||
base.archivesName.convention(
|
base.archivesName.convention("cc-tweaked-$mcVersion-${project.name}")
|
||||||
// TODO: Remove this (and the one below) once we've no longer got a root project!
|
|
||||||
if (project.path == rootProject.path) "cc-tweaked-$mcVersion" else "cc-tweaked-$mcVersion-${project.name}",
|
|
||||||
)
|
|
||||||
|
|
||||||
java {
|
java {
|
||||||
toolchain {
|
toolchain {
|
||||||
@ -104,6 +102,8 @@ tasks.withType(JavaCompile::class.java).configureEach {
|
|||||||
tasks.withType(AbstractArchiveTask::class.java).configureEach {
|
tasks.withType(AbstractArchiveTask::class.java).configureEach {
|
||||||
isPreserveFileTimestamps = false
|
isPreserveFileTimestamps = false
|
||||||
isReproducibleFileOrder = true
|
isReproducibleFileOrder = true
|
||||||
|
dirMode = Integer.valueOf("755", 8)
|
||||||
|
fileMode = Integer.valueOf("664", 8)
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.jar {
|
tasks.jar {
|
||||||
@ -112,7 +112,7 @@ tasks.jar {
|
|||||||
"Specification-Title" to "computercraft",
|
"Specification-Title" to "computercraft",
|
||||||
"Specification-Vendor" to "SquidDev",
|
"Specification-Vendor" to "SquidDev",
|
||||||
"Specification-Version" to "1",
|
"Specification-Version" to "1",
|
||||||
"Implementation-Title" to (if (project.path == rootProject.path) "cctweaked" else "cctweaked-${project.name}"),
|
"Implementation-Title" to "cctweaked-${project.name}",
|
||||||
"Implementation-Version" to modVersion,
|
"Implementation-Version" to modVersion,
|
||||||
"Implementation-Vendor" to "SquidDev",
|
"Implementation-Vendor" to "SquidDev",
|
||||||
)
|
)
|
||||||
@ -141,6 +141,14 @@ tasks.withType(JacocoReport::class.java).configureEach {
|
|||||||
reports.html.required.set(true)
|
reports.html.required.set(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
project.plugins.withType(CCTweakedPlugin::class.java) {
|
||||||
|
// Set up jacoco to read from /all/ our source directories.
|
||||||
|
val cct = project.extensions.getByType<CCTweakedExtension>()
|
||||||
|
project.tasks.named("jacocoTestReport", JacocoReport::class.java) {
|
||||||
|
for (ref in cct.sourceSets.get()) sourceDirectories.from(ref.allSource.sourceDirectories)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
spotless {
|
spotless {
|
||||||
encoding = StandardCharsets.UTF_8
|
encoding = StandardCharsets.UTF_8
|
||||||
lineEndings = LineEnding.UNIX
|
lineEndings = LineEnding.UNIX
|
||||||
|
@ -87,16 +87,17 @@ abstract class CCTweakedExtension(
|
|||||||
|
|
||||||
init {
|
init {
|
||||||
sourceDirectories.finalizeValueOnRead()
|
sourceDirectories.finalizeValueOnRead()
|
||||||
|
project.afterEvaluate { sourceDirectories.disallowChanges() }
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mark this project as consuming another project. Its [sourceDirectories] are added, ensuring tasks are set up
|
* Mark this project as consuming another project. Its [sourceDirectories] are added, allowing easier configuration
|
||||||
* correctly.
|
* of run configurations and other tasks which consume sources/classes.
|
||||||
*/
|
*/
|
||||||
fun externalSources(project: Project) {
|
fun externalSources(project: Project) {
|
||||||
val otherCct = project.extensions.getByType(CCTweakedExtension::class.java)
|
val otherCct = project.extensions.getByType(CCTweakedExtension::class.java)
|
||||||
for (sourceSet in otherCct.sourceSets.get()) {
|
for (sourceSet in otherCct.sourceDirectories.get()) {
|
||||||
sourceDirectories.add(SourceSetReference.external(sourceSet))
|
sourceDirectories.add(SourceSetReference(sourceSet.sourceSet, classes = sourceSet.classes, external = true))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,27 +2,20 @@ package cc.tweaked.gradle
|
|||||||
|
|
||||||
import org.gradle.api.Plugin
|
import org.gradle.api.Plugin
|
||||||
import org.gradle.api.Project
|
import org.gradle.api.Project
|
||||||
import org.gradle.api.tasks.SourceSetContainer
|
import org.gradle.api.plugins.JavaPlugin
|
||||||
|
import org.gradle.api.plugins.JavaPluginExtension
|
||||||
import org.gradle.jvm.toolchain.JavaLanguageVersion
|
import org.gradle.jvm.toolchain.JavaLanguageVersion
|
||||||
import org.gradle.testing.jacoco.tasks.JacocoReport
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Configures projects to match a shared configuration.
|
* Configures projects to match a shared configuration.
|
||||||
*/
|
*/
|
||||||
class CCTweakedPlugin : Plugin<Project> {
|
class CCTweakedPlugin : Plugin<Project> {
|
||||||
override fun apply(project: Project) {
|
override fun apply(project: Project) {
|
||||||
val sourceSets = project.extensions.getByType(SourceSetContainer::class.java)
|
|
||||||
|
|
||||||
val cct = project.extensions.create("cct", CCTweakedExtension::class.java)
|
val cct = project.extensions.create("cct", CCTweakedExtension::class.java)
|
||||||
cct.sourceDirectories.add(SourceSetReference.internal(sourceSets.getByName("main")))
|
|
||||||
|
|
||||||
project.afterEvaluate {
|
project.plugins.withType(JavaPlugin::class.java) {
|
||||||
cct.sourceDirectories.disallowChanges()
|
val sourceSets = project.extensions.getByType(JavaPluginExtension::class.java).sourceSets
|
||||||
}
|
cct.sourceDirectories.add(SourceSetReference.internal(sourceSets.getByName("main")))
|
||||||
|
|
||||||
// Set up jacoco to read from /all/ our source directories.
|
|
||||||
project.tasks.named("jacocoTestReport", JacocoReport::class.java) {
|
|
||||||
for (ref in cct.sourceSets.get()) sourceDirectories.from(ref.allSource.sourceDirectories)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,15 @@
|
|||||||
package cc.tweaked.gradle
|
package cc.tweaked.gradle
|
||||||
|
|
||||||
|
import org.gradle.api.artifacts.ResolvedDependency
|
||||||
import org.gradle.api.artifacts.dsl.DependencyHandler
|
import org.gradle.api.artifacts.dsl.DependencyHandler
|
||||||
|
import org.gradle.api.publish.maven.MavenPublication
|
||||||
|
import org.gradle.api.specs.Spec
|
||||||
import org.gradle.api.tasks.JavaExec
|
import org.gradle.api.tasks.JavaExec
|
||||||
|
import org.gradle.process.JavaExecSpec
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an annotation processor to all source sets.
|
||||||
|
*/
|
||||||
fun DependencyHandler.annotationProcessorEverywhere(dep: Any) {
|
fun DependencyHandler.annotationProcessorEverywhere(dep: Any) {
|
||||||
add("compileOnly", dep)
|
add("compileOnly", dep)
|
||||||
add("annotationProcessor", dep)
|
add("annotationProcessor", dep)
|
||||||
@ -14,6 +21,9 @@ fun DependencyHandler.annotationProcessorEverywhere(dep: Any) {
|
|||||||
add("testAnnotationProcessor", dep)
|
add("testAnnotationProcessor", dep)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A version of [JavaExecSpec.copyTo] which copies *all* properties.
|
||||||
|
*/
|
||||||
fun JavaExec.copyToFull(spec: JavaExec) {
|
fun JavaExec.copyToFull(spec: JavaExec) {
|
||||||
copyTo(spec)
|
copyTo(spec)
|
||||||
spec.classpath = classpath
|
spec.classpath = classpath
|
||||||
|
@ -0,0 +1,62 @@
|
|||||||
|
package cc.tweaked.gradle
|
||||||
|
|
||||||
|
import org.gradle.api.artifacts.Dependency
|
||||||
|
import org.gradle.api.artifacts.MinimalExternalModuleDependency
|
||||||
|
import org.gradle.api.publish.maven.MavenPublication
|
||||||
|
import org.gradle.api.specs.Spec
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A dependency in a POM file.
|
||||||
|
*/
|
||||||
|
data class MavenDependency(val groupId: String?, val artifactId: String?, val version: String?, val scope: String?)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A spec specifying which dependencies to include/exclude.
|
||||||
|
*/
|
||||||
|
class MavenDependencySpec {
|
||||||
|
private val excludeSpecs = mutableListOf<Spec<MavenDependency>>()
|
||||||
|
|
||||||
|
fun exclude(spec: Spec<MavenDependency>) {
|
||||||
|
excludeSpecs.add(spec)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun exclude(dep: Dependency) {
|
||||||
|
exclude {
|
||||||
|
(dep.group.isNullOrEmpty() || dep.group == it.groupId) &&
|
||||||
|
(dep.name.isNullOrEmpty() || dep.name == it.artifactId) &&
|
||||||
|
(dep.version.isNullOrEmpty() || dep.version == it.version)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun exclude(dep: MinimalExternalModuleDependency) {
|
||||||
|
exclude {
|
||||||
|
dep.module.group == it.groupId && dep.module.name == it.artifactId
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun isIncluded(dep: MavenDependency) = !excludeSpecs.any { it.isSatisfiedBy(dep) }
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure dependencies present in this publication's POM file.
|
||||||
|
*
|
||||||
|
* While this approach is very ugly, it's the easiest way to handle it!
|
||||||
|
*/
|
||||||
|
fun MavenPublication.mavenDependencies(action: MavenDependencySpec.() -> Unit) {
|
||||||
|
val spec = MavenDependencySpec()
|
||||||
|
action(spec)
|
||||||
|
|
||||||
|
pom.withXml {
|
||||||
|
val dependencies = XmlUtil.findChild(asNode(), "dependencies") ?: return@withXml
|
||||||
|
dependencies.children().map { it as groovy.util.Node }.forEach {
|
||||||
|
val dep = MavenDependency(
|
||||||
|
groupId = XmlUtil.findChild(it, "groupId")?.text(),
|
||||||
|
artifactId = XmlUtil.findChild(it, "artifactId")?.text(),
|
||||||
|
version = XmlUtil.findChild(it, "version")?.text(),
|
||||||
|
scope = XmlUtil.findChild(it, "scope")?.text(),
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!spec.isIncluded(dep)) it.parent().remove(it)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
12
buildSrc/src/main/kotlin/cc/tweaked/gradle/XmlUtil.kt
Normal file
12
buildSrc/src/main/kotlin/cc/tweaked/gradle/XmlUtil.kt
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
package cc.tweaked.gradle
|
||||||
|
|
||||||
|
import groovy.util.Node
|
||||||
|
import groovy.util.NodeList
|
||||||
|
|
||||||
|
object XmlUtil {
|
||||||
|
fun findChild(node: Node, name: String): Node? = when (val child = node.get(name)) {
|
||||||
|
is Node -> child
|
||||||
|
is NodeList -> child.singleOrNull() as Node?
|
||||||
|
else -> null
|
||||||
|
}
|
||||||
|
}
|
@ -5,7 +5,8 @@ kotlin.stdlib.default.dependency=false
|
|||||||
kotlin.jvm.target.validation.mode=error
|
kotlin.jvm.target.validation.mode=error
|
||||||
|
|
||||||
# Mod properties
|
# Mod properties
|
||||||
modVersion=1.101.1
|
isUnstable=true
|
||||||
|
modVersion=1.102.0-SNAPSHOT
|
||||||
|
|
||||||
# Minecraft properties: We want to configure this here so we can read it in settings.gradle
|
# Minecraft properties: We want to configure this here so we can read it in settings.gradle
|
||||||
mcVersion=1.19.2
|
mcVersion=1.19.2
|
||||||
|
@ -59,7 +59,7 @@ mentioning:
|
|||||||
- `web`: This contains the additional tooling for building [the documentation website][tweaked.cc], such as support for
|
- `web`: This contains the additional tooling for building [the documentation website][tweaked.cc], such as support for
|
||||||
rendering recipes
|
rendering recipes
|
||||||
|
|
||||||
- `build-logic` (in the base directory, not in `projects/`): This contains any build logic shared between modules. For
|
- `buildSrc` (in the base directory, not in `projects/`): This contains any build logic shared between modules. For
|
||||||
instance, `cc-tweaked.java-convention.gradle.kts` sets up the defaults for Java that we use across the whole project.
|
instance, `cc-tweaked.java-convention.gradle.kts` sets up the defaults for Java that we use across the whole project.
|
||||||
|
|
||||||
> **Note**
|
> **Note**
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
package dan200.computercraft.client.sound;
|
package dan200.computercraft.client.sound;
|
||||||
|
|
||||||
|
import dan200.computercraft.annotations.FabricOverride;
|
||||||
import dan200.computercraft.annotations.ForgeOverride;
|
import dan200.computercraft.annotations.ForgeOverride;
|
||||||
import dan200.computercraft.shared.peripheral.speaker.SpeakerPosition;
|
import dan200.computercraft.shared.peripheral.speaker.SpeakerPosition;
|
||||||
import net.minecraft.client.resources.sounds.AbstractSoundInstance;
|
import net.minecraft.client.resources.sounds.AbstractSoundInstance;
|
||||||
@ -64,7 +65,12 @@ public class SpeakerSound extends AbstractSoundInstance implements TickableSound
|
|||||||
|
|
||||||
@ForgeOverride
|
@ForgeOverride
|
||||||
public CompletableFuture<AudioStream> getStream(SoundBufferLibrary soundBuffers, Sound sound, boolean looping) {
|
public CompletableFuture<AudioStream> getStream(SoundBufferLibrary soundBuffers, Sound sound, boolean looping) {
|
||||||
return stream != null ? CompletableFuture.completedFuture(stream) : soundBuffers.getStream(sound.getPath(), looping);
|
return getAudioStream(soundBuffers, sound.getPath(), looping);
|
||||||
|
}
|
||||||
|
|
||||||
|
@FabricOverride
|
||||||
|
public CompletableFuture<AudioStream> getAudioStream(SoundBufferLibrary soundBuffers, ResourceLocation sound, boolean looping) {
|
||||||
|
return stream != null ? CompletableFuture.completedFuture(stream) : soundBuffers.getStream(sound, looping);
|
||||||
}
|
}
|
||||||
|
|
||||||
public @Nullable AudioStream getStream() {
|
public @Nullable AudioStream getStream() {
|
||||||
|
@ -0,0 +1,17 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||||
|
* Copyright Daniel Ratcliffe, 2011-2022. Do not distribute without permission.
|
||||||
|
* Send enquiries to dratcliffe@gmail.com
|
||||||
|
*/
|
||||||
|
package dan200.computercraft.annotations;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Equivalent to {@link Override}, but for Fabric-specific methods.
|
||||||
|
*/
|
||||||
|
@Documented
|
||||||
|
@Retention(RetentionPolicy.SOURCE)
|
||||||
|
@Target(ElementType.METHOD)
|
||||||
|
public @interface FabricOverride {
|
||||||
|
}
|
@ -1,3 +1,7 @@
|
|||||||
|
# New features in CC: Tweaked 1.102.0-SNAPSHOT
|
||||||
|
|
||||||
|
No user-facing changes.
|
||||||
|
|
||||||
# New features in CC: Tweaked 1.101.1
|
# New features in CC: Tweaked 1.101.1
|
||||||
|
|
||||||
Several bug fixes:
|
Several bug fixes:
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
New features in CC: Tweaked 1.101.1
|
New features in CC: Tweaked 1.102.0-SNAPSHOT
|
||||||
|
|
||||||
Several bug fixes:
|
No user-facing changes.
|
||||||
* Improve validation of rednet messages (Ale32bit)
|
|
||||||
* Fix `turtle.refuel()` always failing.
|
|
||||||
|
|
||||||
Type "help changelog" to see the full version history.
|
Type "help changelog" to see the full version history.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
plugins {
|
plugins {
|
||||||
id("cc-tweaked.publishing")
|
|
||||||
id("cc-tweaked.fabric")
|
id("cc-tweaked.fabric")
|
||||||
|
id("cc-tweaked.publishing")
|
||||||
}
|
}
|
||||||
|
|
||||||
val mcVersion: String by extra
|
val mcVersion: String by extra
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
import cc.tweaked.gradle.annotationProcessorEverywhere
|
import cc.tweaked.gradle.annotationProcessorEverywhere
|
||||||
import cc.tweaked.gradle.clientClasses
|
import cc.tweaked.gradle.clientClasses
|
||||||
import cc.tweaked.gradle.commonClasses
|
import cc.tweaked.gradle.commonClasses
|
||||||
|
import cc.tweaked.gradle.mavenDependencies
|
||||||
import net.fabricmc.loom.configuration.ide.RunConfigSettings
|
import net.fabricmc.loom.configuration.ide.RunConfigSettings
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
id("cc-tweaked.fabric")
|
id("cc-tweaked.fabric")
|
||||||
id("cc-tweaked.gametest")
|
id("cc-tweaked.gametest")
|
||||||
|
id("cc-tweaked.publishing")
|
||||||
}
|
}
|
||||||
|
|
||||||
val modVersion: String by extra
|
val modVersion: String by extra
|
||||||
@ -35,10 +37,15 @@ dependencies {
|
|||||||
include(libs.nightConfig.toml)
|
include(libs.nightConfig.toml)
|
||||||
|
|
||||||
// Pull in our other projects. See comments in MinecraftConfigurations on this nastiness.
|
// Pull in our other projects. See comments in MinecraftConfigurations on this nastiness.
|
||||||
|
api(commonClasses(project(":fabric-api")))
|
||||||
|
clientApi(clientClasses(project(":fabric-api")))
|
||||||
implementation(project(":core"))
|
implementation(project(":core"))
|
||||||
|
// These are transitive deps of :core, so we don't need these deps. However, we want them to appear as runtime deps
|
||||||
|
// in our POM, and this is the easiest way.
|
||||||
|
runtimeOnly(libs.cobalt)
|
||||||
|
runtimeOnly(libs.netty.http)
|
||||||
|
|
||||||
compileOnly(project(":forge-stubs"))
|
compileOnly(project(":forge-stubs"))
|
||||||
implementation(commonClasses(project(":fabric-api")))
|
|
||||||
clientImplementation(clientClasses(project(":fabric-api")))
|
|
||||||
|
|
||||||
annotationProcessorEverywhere(libs.autoService)
|
annotationProcessorEverywhere(libs.autoService)
|
||||||
|
|
||||||
@ -137,7 +144,13 @@ tasks.processResources {
|
|||||||
}
|
}
|
||||||
|
|
||||||
tasks.jar {
|
tasks.jar {
|
||||||
from(allProjects.map { zipTree(it.tasks.jar.get().archiveFile) })
|
for (source in cct.sourceDirectories.get()) {
|
||||||
|
if (source.classes && source.external) from(source.sourceSet.output)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.sourcesJar {
|
||||||
|
for (source in cct.sourceDirectories.get()) from(source.sourceSet.allSource)
|
||||||
}
|
}
|
||||||
|
|
||||||
val validateMixinNames by tasks.registering(net.fabricmc.loom.task.ValidateMixinNameTask::class) {
|
val validateMixinNames by tasks.registering(net.fabricmc.loom.task.ValidateMixinNameTask::class) {
|
||||||
@ -153,3 +166,15 @@ val runGametest = tasks.named<JavaExec>("runGametest")
|
|||||||
cct.jacoco(runGametest)
|
cct.jacoco(runGametest)
|
||||||
|
|
||||||
tasks.check { dependsOn(validateMixinNames, runGametest) }
|
tasks.check { dependsOn(validateMixinNames, runGametest) }
|
||||||
|
|
||||||
|
tasks.withType(GenerateModuleMetadata::class).configureEach { isEnabled = false }
|
||||||
|
publishing {
|
||||||
|
publications {
|
||||||
|
named("maven", MavenPublication::class) {
|
||||||
|
mavenDependencies {
|
||||||
|
exclude(dependencies.create("cc.tweaked:"))
|
||||||
|
exclude(libs.jei.fabric.get())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
import cc.tweaked.gradle.*
|
import cc.tweaked.gradle.*
|
||||||
import groovy.util.Node
|
|
||||||
import groovy.util.NodeList
|
|
||||||
import net.darkhax.curseforgegradle.TaskPublishCurseForge
|
import net.darkhax.curseforgegradle.TaskPublishCurseForge
|
||||||
import net.minecraftforge.gradle.common.util.RunConfig
|
import net.minecraftforge.gradle.common.util.RunConfig
|
||||||
|
|
||||||
@ -12,7 +10,6 @@ plugins {
|
|||||||
alias(libs.plugins.shadow)
|
alias(libs.plugins.shadow)
|
||||||
// Publishing
|
// Publishing
|
||||||
alias(libs.plugins.curseForgeGradle)
|
alias(libs.plugins.curseForgeGradle)
|
||||||
alias(libs.plugins.githubRelease)
|
|
||||||
alias(libs.plugins.minotaur)
|
alias(libs.plugins.minotaur)
|
||||||
|
|
||||||
id("cc-tweaked.illuaminate")
|
id("cc-tweaked.illuaminate")
|
||||||
@ -20,7 +17,7 @@ plugins {
|
|||||||
id("cc-tweaked")
|
id("cc-tweaked")
|
||||||
}
|
}
|
||||||
|
|
||||||
val isStable = true
|
val isUnstable = project.properties["isUnstable"] == "true"
|
||||||
val modVersion: String by extra
|
val modVersion: String by extra
|
||||||
val mcVersion: String by extra
|
val mcVersion: String by extra
|
||||||
|
|
||||||
@ -41,10 +38,6 @@ minecraft {
|
|||||||
// configureEach would be better, but we need to eagerly configure configs or otherwise the run task doesn't
|
// configureEach would be better, but we need to eagerly configure configs or otherwise the run task doesn't
|
||||||
// get set up properly.
|
// get set up properly.
|
||||||
all {
|
all {
|
||||||
lazyToken("minecraft_classpath") {
|
|
||||||
configurations["shade"].copyRecursive().resolve().joinToString(File.pathSeparator) { it.absolutePath }
|
|
||||||
}
|
|
||||||
|
|
||||||
property("forge.logging.markers", "REGISTRIES")
|
property("forge.logging.markers", "REGISTRIES")
|
||||||
property("forge.logging.console.level", "debug")
|
property("forge.logging.console.level", "debug")
|
||||||
|
|
||||||
@ -78,7 +71,7 @@ minecraft {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fun RunConfig.configureForGameTest() {
|
fun RunConfig.configureForGameTest() {
|
||||||
val old = lazyTokens.get("minecraft_classpath")
|
val old = lazyTokens["minecraft_classpath"]
|
||||||
lazyToken("minecraft_classpath") {
|
lazyToken("minecraft_classpath") {
|
||||||
// We do some terrible hacks here to basically find all things not already on the runtime classpath
|
// We do some terrible hacks here to basically find all things not already on the runtime classpath
|
||||||
// and add them. /Except/ for our source sets, as those need to load inside the Minecraft classpath.
|
// and add them. /Except/ for our source sets, as those need to load inside the Minecraft classpath.
|
||||||
@ -89,7 +82,9 @@ minecraft {
|
|||||||
.filter { it.isFile && !it.name.endsWith("-test-fixtures.jar") }
|
.filter { it.isFile && !it.name.endsWith("-test-fixtures.jar") }
|
||||||
.map { it.absolutePath }
|
.map { it.absolutePath }
|
||||||
.joinToString(File.pathSeparator)
|
.joinToString(File.pathSeparator)
|
||||||
if (old == null) new else old.get() + File.pathSeparator + new
|
|
||||||
|
val oldVal = old?.get()
|
||||||
|
if (oldVal.isNullOrEmpty()) new else oldVal + File.pathSeparator + new
|
||||||
}
|
}
|
||||||
|
|
||||||
property("cctest.sources", project(":common").file("src/testMod/resources/data/cctest").absolutePath)
|
property("cctest.sources", project(":common").file("src/testMod/resources/data/cctest").absolutePath)
|
||||||
@ -131,8 +126,6 @@ reobf {
|
|||||||
}
|
}
|
||||||
|
|
||||||
configurations {
|
configurations {
|
||||||
val shade by registering { isTransitive = false }
|
|
||||||
implementation { extendsFrom(shade.get()) }
|
|
||||||
register("cctJavadoc")
|
register("cctJavadoc")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,11 +138,14 @@ dependencies {
|
|||||||
libs.bundles.externalMods.forge.compile.get().map { compileOnly(fg.deobf(it)) }
|
libs.bundles.externalMods.forge.compile.get().map { compileOnly(fg.deobf(it)) }
|
||||||
libs.bundles.externalMods.forge.runtime.get().map { runtimeOnly(fg.deobf(it)) }
|
libs.bundles.externalMods.forge.runtime.get().map { runtimeOnly(fg.deobf(it)) }
|
||||||
|
|
||||||
|
// Depend on our other projects. By using the api configuration, shadow jar will correctly
|
||||||
|
// preserve all files from forge-api/core-api.
|
||||||
|
api(commonClasses(project(":forge-api")))
|
||||||
|
api(clientClasses(project(":forge-api")))
|
||||||
implementation(project(":core"))
|
implementation(project(":core"))
|
||||||
implementation(commonClasses(project(":forge-api")))
|
|
||||||
implementation(clientClasses(project(":forge-api")))
|
minecraftLibrary(libs.cobalt)
|
||||||
"shade"(libs.cobalt)
|
minecraftLibrary(libs.netty.http) { isTransitive = false }
|
||||||
"shade"(libs.netty.http)
|
|
||||||
|
|
||||||
testFixturesApi(libs.bundles.test)
|
testFixturesApi(libs.bundles.test)
|
||||||
testFixturesApi(libs.bundles.kotlin)
|
testFixturesApi(libs.bundles.kotlin)
|
||||||
@ -206,19 +202,27 @@ tasks.jar {
|
|||||||
finalizedBy("reobfJar")
|
finalizedBy("reobfJar")
|
||||||
archiveClassifier.set("slim")
|
archiveClassifier.set("slim")
|
||||||
|
|
||||||
from(allProjects.map { zipTree(it.tasks.jar.get().archiveFile) })
|
for (source in cct.sourceDirectories.get()) {
|
||||||
|
if (source.classes && source.external) from(source.sourceSet.output)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.sourcesJar {
|
||||||
|
for (source in cct.sourceDirectories.get()) from(source.sourceSet.allSource)
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.shadowJar {
|
tasks.shadowJar {
|
||||||
finalizedBy("reobfShadowJar")
|
finalizedBy("reobfShadowJar")
|
||||||
archiveClassifier.set("")
|
archiveClassifier.set("")
|
||||||
|
|
||||||
from(allProjects.map { zipTree(it.tasks.jar.get().archiveFile) })
|
dependencies {
|
||||||
|
include(dependency("cc.tweaked:"))
|
||||||
configurations = listOf(project.configurations["shade"])
|
include(dependency(libs.cobalt.get()))
|
||||||
|
include(dependency(libs.netty.http.get()))
|
||||||
|
}
|
||||||
relocate("org.squiddev.cobalt", "cc.tweaked.internal.cobalt")
|
relocate("org.squiddev.cobalt", "cc.tweaked.internal.cobalt")
|
||||||
relocate("io.netty.handler", "cc.tweaked.internal.netty")
|
relocate("io.netty.handler", "cc.tweaked.internal.netty")
|
||||||
// TODO: minimize(): Would be good to support once our build scripts are stabilised.
|
minimize()
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.assemble { dependsOn("shadowJar") }
|
tasks.assemble { dependsOn("shadowJar") }
|
||||||
@ -276,7 +280,7 @@ val publishCurseForge by tasks.registering(TaskPublishCurseForge::class) {
|
|||||||
mainFile.changelog =
|
mainFile.changelog =
|
||||||
"Release notes can be found on the [GitHub repository](https://github.com/cc-tweaked/CC-Tweaked/releases/tag/v$mcVersion-$modVersion)."
|
"Release notes can be found on the [GitHub repository](https://github.com/cc-tweaked/CC-Tweaked/releases/tag/v$mcVersion-$modVersion)."
|
||||||
mainFile.changelogType = "markdown"
|
mainFile.changelogType = "markdown"
|
||||||
mainFile.releaseType = if (isStable) "release" else "alpha"
|
mainFile.releaseType = if (isUnstable) "alpha" else "release"
|
||||||
mainFile.gameVersions.add(mcVersion)
|
mainFile.gameVersions.add(mcVersion)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +291,7 @@ modrinth {
|
|||||||
projectId.set("gu7yAYhd")
|
projectId.set("gu7yAYhd")
|
||||||
versionNumber.set("$mcVersion-$modVersion")
|
versionNumber.set("$mcVersion-$modVersion")
|
||||||
versionName.set(modVersion)
|
versionName.set(modVersion)
|
||||||
versionType.set(if (isStable) "release" else "alpha")
|
versionType.set(if (isUnstable) "alpha" else "release")
|
||||||
uploadFile.set(tasks.shadowJar as Any)
|
uploadFile.set(tasks.shadowJar as Any)
|
||||||
gameVersions.add(mcVersion)
|
gameVersions.add(mcVersion)
|
||||||
changelog.set("Release notes can be found on the [GitHub repository](https://github.com/cc-tweaked/CC-Tweaked/releases/tag/v$mcVersion-$modVersion).")
|
changelog.set("Release notes can be found on the [GitHub repository](https://github.com/cc-tweaked/CC-Tweaked/releases/tag/v$mcVersion-$modVersion).")
|
||||||
@ -297,27 +301,6 @@ modrinth {
|
|||||||
|
|
||||||
tasks.publish { dependsOn(tasks.modrinth) }
|
tasks.publish { dependsOn(tasks.modrinth) }
|
||||||
|
|
||||||
githubRelease {
|
|
||||||
token(findProperty("githubApiKey") as String? ?: "")
|
|
||||||
owner.set("cc-tweaked")
|
|
||||||
repo.set("CC-Tweaked")
|
|
||||||
targetCommitish.set(cct.gitBranch)
|
|
||||||
|
|
||||||
tagName.set("v$mcVersion-$modVersion")
|
|
||||||
releaseName.set("[$mcVersion] $modVersion")
|
|
||||||
body.set(
|
|
||||||
provider {
|
|
||||||
"## " + file("src/main/resources/data/computercraft/lua/rom/help/whatsnew.md")
|
|
||||||
.readLines()
|
|
||||||
.takeWhile { it != "Type \"help changelog\" to see the full version history." }
|
|
||||||
.joinToString("\n").trim()
|
|
||||||
},
|
|
||||||
)
|
|
||||||
prerelease.set(!isStable)
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.publish { dependsOn(tasks.githubRelease) }
|
|
||||||
|
|
||||||
// Don't publish the slim jar
|
// Don't publish the slim jar
|
||||||
for (cfg in listOf(configurations.apiElements, configurations.runtimeElements)) {
|
for (cfg in listOf(configurations.apiElements, configurations.runtimeElements)) {
|
||||||
cfg.configure { artifacts.removeIf { it.classifier == "slim" } }
|
cfg.configure { artifacts.removeIf { it.classifier == "slim" } }
|
||||||
@ -327,11 +310,9 @@ publishing {
|
|||||||
publications {
|
publications {
|
||||||
named("maven", MavenPublication::class) {
|
named("maven", MavenPublication::class) {
|
||||||
fg.component(this)
|
fg.component(this)
|
||||||
// Remove all dependencies: they're shaded anyway! This is very ugly, but not found a better way :(.
|
mavenDependencies {
|
||||||
pom.withXml {
|
exclude(dependencies.create("cc.tweaked:"))
|
||||||
for (node in asNode().get("dependencies") as NodeList) {
|
exclude(libs.jei.forge.get())
|
||||||
asNode().remove(node as Node)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user