1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2026-06-08 05:42:06 +00:00
Files
CC-Tweaked/build.gradle
T

550 lines
17 KiB
Groovy
Raw Normal View History

2017-05-01 14:32:39 +01:00
buildscript {
repositories {
jcenter()
2019-04-02 13:27:27 +01:00
mavenCentral()
2017-05-01 14:32:39 +01:00
maven {
name = "forge"
2019-06-21 17:51:55 +02:00
url = "https://files.minecraftforge.net/maven"
2017-05-01 14:32:39 +01:00
}
}
dependencies {
2019-02-14 10:53:18 +00:00
classpath 'com.google.code.gson:gson:2.8.1'
classpath 'net.minecraftforge.gradle:ForgeGradle:3.0.187'
2019-04-02 13:27:27 +01:00
classpath 'net.sf.proguard:proguard-gradle:6.1.0beta2'
2019-01-28 14:05:30 +00:00
classpath 'org.ajoberstar.grgit:grgit-gradle:3.0.0'
2017-05-01 14:32:39 +01:00
}
}
2017-12-01 20:05:26 +00:00
plugins {
id "checkstyle"
2020-05-11 15:41:39 +01:00
id "jacoco"
id "com.github.hierynomus.license" version "0.15.0"
id "com.matthewprenger.cursegradle" version "1.3.0"
2019-04-07 15:30:27 +01:00
id "com.github.breadmoirai.github-release" version "2.2.4"
2017-12-01 20:05:26 +00:00
}
2019-04-02 13:27:27 +01:00
apply plugin: 'net.minecraftforge.gradle'
apply plugin: 'org.ajoberstar.grgit'
2018-04-19 22:36:00 +01:00
apply plugin: 'maven-publish'
apply plugin: 'maven'
2017-05-01 14:32:39 +01:00
2019-03-19 11:47:12 +00:00
version = mod_version
2019-02-19 14:49:13 +00:00
2017-11-15 16:25:10 +00:00
group = "org.squiddev"
2019-03-19 11:47:12 +00:00
archivesBaseName = "cc-tweaked-${mc_version}"
2017-05-01 14:32:39 +01:00
2020-07-03 13:31:26 +01:00
sourceCompatibility = targetCompatibility = compileJava.sourceCompatibility = compileJava.targetCompatibility = '1.8'
2017-05-01 14:32:39 +01:00
minecraft {
2019-04-02 13:27:27 +01:00
runs {
client {
workingDirectory project.file('run')
property 'forge.logging.markers', 'REGISTRIES'
property 'forge.logging.console.level', 'debug'
2017-07-06 17:23:35 +01:00
2019-04-02 13:27:27 +01:00
mods {
computercraft {
source sourceSets.main
}
}
}
server {
2020-04-22 11:04:29 +01:00
workingDirectory project.file("run/server-${mc_version}")
property 'forge.logging.markers', 'REGISTRIES,REGISTRYDUMP'
2019-04-02 13:27:27 +01:00
property 'forge.logging.console.level', 'debug'
mods {
computercraft {
source sourceSets.main
}
}
}
data {
workingDirectory project.file('run')
property 'forge.logging.markers', 'REGISTRIES,REGISTRYDUMP'
property 'forge.logging.console.level', 'debug'
args '--mod', 'computercraft', '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/')
mods {
computercraft {
source sourceSets.main
}
}
}
2019-04-02 13:27:27 +01:00
}
mappings channel: 'snapshot', version: "${mappings_version}".toString()
accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg')
2017-05-01 14:32:39 +01:00
}
2020-07-03 13:31:26 +01:00
sourceSets {
main.resources {
srcDir 'src/generated/resources'
}
}
2017-10-25 13:40:35 +01:00
repositories {
2020-07-03 13:31:26 +01:00
mavenCentral()
2017-05-01 17:49:22 +01:00
maven {
2019-03-19 11:47:12 +00:00
name "SquidDev"
url "https://squiddev.cc/maven"
}
2017-05-01 17:49:22 +01:00
}
configurations {
shade
compile.extendsFrom shade
2018-04-19 22:36:00 +01:00
deployerJars
2020-07-03 13:31:26 +01:00
cctJavadoc
2017-10-25 13:40:35 +01:00
}
2017-05-01 14:32:39 +01:00
dependencies {
checkstyle "com.puppycrawl.tools:checkstyle:8.25"
2019-04-02 13:27:27 +01:00
minecraft "net.minecraftforge:forge:${mc_version}-${forge_version}"
2018-08-11 10:48:41 +01:00
2020-04-22 11:04:29 +01:00
compileOnly fg.deobf("mezz.jei:jei-1.15.2:6.0.0.3:api")
2020-04-22 11:11:02 +01:00
compileOnly fg.deobf("com.blamejared.crafttweaker:CraftTweaker-1.15.2:6.0.0.9")
2020-04-22 11:04:29 +01:00
runtimeOnly fg.deobf("mezz.jei:jei-1.15.2:6.0.0.3")
2018-08-11 10:48:41 +01:00
compileOnly 'com.google.auto.service:auto-service:1.0-rc7'
annotationProcessor 'com.google.auto.service:auto-service:1.0-rc7'
2020-04-16 10:48:26 +01:00
shade 'org.squiddev:Cobalt:0.5.1-SNAPSHOT'
2019-06-15 11:05:45 +01:00
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.4.2'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.4.2'
testImplementation 'org.hamcrest:hamcrest:2.2'
2018-04-19 22:36:00 +01:00
deployerJars "org.apache.maven.wagon:wagon-ssh:3.0.0"
2020-07-03 13:31:26 +01:00
2020-10-31 12:50:03 +00:00
cctJavadoc 'cc.tweaked:cct-javadoc:1.2.1'
2017-05-01 14:32:39 +01:00
}
2019-06-15 11:05:45 +01:00
// Compile tasks
2017-11-14 22:37:37 +00:00
javadoc {
include "dan200/computercraft/api/**/*.java"
}
2020-07-03 13:31:26 +01:00
task luaJavadoc(type: Javadoc) {
description "Generates documentation for Java-side Lua functions."
group "documentation"
source = sourceSets.main.allJava
2020-11-12 19:01:50 +00:00
destinationDir = file("${project.docsDir}/luaJavadoc")
2020-07-03 13:31:26 +01:00
classpath = sourceSets.main.compileClasspath
options.docletpath = configurations.cctJavadoc.files as List
options.doclet = "cc.tweaked.javadoc.LuaDoclet"
// Attempt to run under Java 11 (any Java >= 9 will work though).
if(System.getProperty("java.version").startsWith("1.")
&& (System.getenv("JAVA_HOME_11_X64") != null || project.hasProperty("java11Home"))) {
executable = "${System.getenv("JAVA_HOME_11_X64") ?: project.property("java11Home")}/bin/javadoc"
}
}
2017-05-14 17:00:14 +01:00
jar {
2017-11-14 22:37:37 +00:00
dependsOn javadoc
2017-05-14 17:00:14 +01:00
manifest {
2019-04-02 13:27:27 +01:00
attributes(["Specification-Title": "computercraft",
"Specification-Vendor": "SquidDev",
2019-07-21 09:41:58 +01:00
"Specification-Version": "1",
2019-04-02 13:27:27 +01:00
"Implementation-Title": "CC: Tweaked",
"Implementation-Version": "${mod_version}",
"Implementation-Vendor" :"SquidDev",
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")])
2017-05-14 17:00:14 +01:00
}
2019-02-19 14:49:13 +00:00
from (sourceSets.main.allSource) {
2017-11-14 22:37:37 +00:00
include "dan200/computercraft/api/**/*.java"
2019-02-19 14:49:13 +00:00
}
2017-11-14 22:37:37 +00:00
from configurations.shade.collect { it.isDirectory() ? it : zipTree(it) }
2017-05-14 17:00:14 +01:00
}
2019-06-15 11:05:45 +01:00
[compileJava, compileTestJava].forEach {
it.configure {
2019-12-24 19:16:06 +00:00
options.compilerArgs << "-Xlint" << "-Xlint:-processing"
2019-06-15 11:05:45 +01:00
}
}
2019-02-14 10:53:18 +00:00
import java.nio.charset.StandardCharsets
import java.nio.file.*
import java.util.zip.*
import com.google.gson.GsonBuilder
import com.google.gson.JsonElement
import com.hierynomus.gradle.license.tasks.LicenseCheck
import com.hierynomus.gradle.license.tasks.LicenseFormat
import org.ajoberstar.grgit.Grgit
2019-02-14 10:53:18 +00:00
import proguard.gradle.ProGuardTask
task proguard(type: ProGuardTask, dependsOn: jar) {
description "Removes unused shadowed classes from the jar"
2019-02-16 15:57:35 +00:00
group "compact"
2019-02-14 10:53:18 +00:00
injars jar.archivePath
outjars "${jar.archivePath.absolutePath.replace(".jar", "")}-min.jar"
2019-02-16 15:57:35 +00:00
// Add the main runtime jar and all non-shadowed dependencies
libraryjars "${System.getProperty('java.home')}/lib/rt.jar"
2019-12-23 18:54:19 +00:00
libraryjars "${System.getProperty('java.home')}/lib/jce.jar"
2019-02-16 15:57:35 +00:00
doFirst {
sourceSets.main.compileClasspath
.filter { !it.name.contains("Cobalt") }
.each { libraryjars it }
}
2019-02-14 10:53:18 +00:00
// We want to avoid as much obfuscation as possible. We're only doing this to shrink code size.
dontobfuscate; dontoptimize; keepattributes; keepparameternames
// Proguard will remove directories by default, but that breaks JarMount.
2019-06-02 16:46:45 +01:00
keepdirectories 'data/computercraft/lua**'
2019-02-14 10:53:18 +00:00
// Preserve ComputerCraft classes - we only want to strip shadowed files.
keep 'class dan200.computercraft.** { *; }'
2019-04-02 13:27:27 +01:00
// LWJGL and Apache bundle Java 9 versions, which is great, but rather breaks Proguard
dontwarn 'module-info'
dontwarn 'org.apache.**,org.lwjgl.**'
2019-02-14 10:53:18 +00:00
}
task proguardMove(dependsOn: proguard) {
description "Replace the original jar with the minified version"
group "compact"
doLast {
Files.move(
file("${jar.archivePath.absolutePath.replace(".jar", "")}-min.jar").toPath(),
file(jar.archivePath).toPath(),
StandardCopyOption.REPLACE_EXISTING
)
}
}
processResources {
2019-03-19 11:47:12 +00:00
inputs.property "version", mod_version
2019-02-20 09:48:16 +00:00
inputs.property "mcversion", mc_version
2017-05-01 14:32:39 +01:00
2019-01-28 14:05:30 +00:00
def hash = 'none'
2017-05-24 13:20:46 -04:00
Set<String> contributors = []
2019-01-28 14:05:30 +00:00
try {
def grgit = Grgit.open(dir: '.')
hash = grgit.head().id
2017-07-06 17:23:35 +01:00
2019-01-28 14:05:30 +00:00
def blacklist = ['GitHub', 'dan200', 'Daniel Ratcliffe']
grgit.log().each {
if (!blacklist.contains(it.author.name)) contributors.add(it.author.name)
if (!blacklist.contains(it.committer.name)) contributors.add(it.committer.name)
}
} catch(Exception ignored) { }
inputs.property "commithash", hash
2017-05-24 13:20:46 -04:00
2017-05-01 14:32:39 +01:00
from(sourceSets.main.resources.srcDirs) {
2019-04-02 13:27:27 +01:00
include 'META-INF/mods.toml'
include 'data/computercraft/lua/rom/help/credits.txt'
2017-05-24 13:20:46 -04:00
2019-03-19 11:47:12 +00:00
expand 'version': mod_version,
2019-02-20 09:48:16 +00:00
'mcversion': mc_version,
'gitcontributors': contributors.sort(false, String.CASE_INSENSITIVE_ORDER).join('\n')
2017-07-06 17:23:35 +01:00
}
2017-05-01 14:32:39 +01:00
from(sourceSets.main.resources.srcDirs) {
2019-04-02 13:27:27 +01:00
exclude 'META-INF/mods.toml'
exclude 'data/computercraft/lua/rom/help/credits.txt'
2017-05-01 14:32:39 +01:00
}
}
2019-04-02 13:27:27 +01:00
task compressJson(dependsOn: jar) {
2019-02-14 10:53:18 +00:00
group "compact"
description "Minifies all JSON files, stripping whitespace"
def jarPath = file(jar.archivePath)
def tempPath = File.createTempFile("input", ".jar", temporaryDir)
tempPath.deleteOnExit()
def gson = new GsonBuilder().create()
doLast {
// Copy over all files in the current jar to the new one, running json files from GSON. As pretty printing
// is turned off, they should be minified.
new ZipFile(jarPath).withCloseable { inJar ->
2019-06-02 18:48:36 +01:00
tempPath.getParentFile().mkdirs()
2019-02-14 10:53:18 +00:00
new ZipOutputStream(new BufferedOutputStream(new FileOutputStream(tempPath))).withCloseable { outJar ->
inJar.entries().each { entry ->
if(entry.directory) {
outJar.putNextEntry(entry)
} else if(!entry.name.endsWith(".json")) {
outJar.putNextEntry(entry)
inJar.getInputStream(entry).withCloseable { outJar << it }
} else {
ZipEntry newEntry = new ZipEntry(entry.name)
newEntry.setTime(entry.time)
outJar.putNextEntry(newEntry)
def element = inJar.getInputStream(entry).withCloseable { gson.fromJson(it.newReader("UTF8"), JsonElement.class) }
outJar.write(gson.toJson(element).getBytes(StandardCharsets.UTF_8))
}
}
}
}
// And replace the original jar again
Files.move(tempPath.toPath(), jarPath.toPath(), StandardCopyOption.REPLACE_EXISTING)
}
}
assemble.dependsOn compressJson
2017-12-01 20:05:26 +00:00
2020-11-12 19:01:50 +00:00
// Web tasks
import org.apache.tools.ant.taskdefs.condition.Os
List<String> mkCommand(String command) {
return Os.isFamily(Os.FAMILY_WINDOWS) ? ["cmd", "/c", command] : ["sh", "-c", command]
}
task rollup(type: Exec) {
group = "build"
description = "Bundles JS into rollup"
inputs.files(fileTree("src/web")).withPropertyName("sources")
inputs.file("package-lock.json").withPropertyName("package-lock.json")
inputs.file("tsconfig.json").withPropertyName("Typescript config")
inputs.file("rollup.config.js").withPropertyName("Rollup config")
outputs.file("$buildDir/rollup/index.js").withPropertyName("output")
commandLine mkCommand('"node_modules/.bin/rollup" --config rollup.config.js')
}
task minifyWeb(type: Exec, dependsOn: rollup) {
group = "build"
description = "Bundles JS into rollup"
inputs.file("$buildDir/rollup/index.js").withPropertyName("sources")
inputs.file("package-lock.json").withPropertyName("package-lock.json")
outputs.file("$buildDir/rollup/index.min.js").withPropertyName("output")
commandLine mkCommand('"node_modules/.bin/terser"' + " -o $buildDir/rollup/index.min.js $buildDir/rollup/index.js")
}
task illuaminateDocs(type: Exec, dependsOn: [minifyWeb, luaJavadoc]) {
group = "build"
description = "Bundles JS into rollup"
inputs.files(fileTree("doc")).withPropertyName("sources")
inputs.file("illuaminate.sexp").withPropertyName("illuaminate.sexp")
inputs.file("$buildDir/rollup/index.min.js").withPropertyName("scripts")
inputs.file("src/web/styles.css").withPropertyName("styles")
outputs.dir("$buildDir/docs/lua")
commandLine mkCommand('"bin/illuaminate" doc-gen')
}
task docWebsite(type: Copy, dependsOn: [illuaminateDocs]) {
from 'doc/logo.png'
into "${project.docsDir}/lua"
}
2019-06-15 11:05:45 +01:00
// Check tasks
test {
useJUnitPlatform()
testLogging {
events "skipped", "failed"
}
}
2020-05-11 15:41:39 +01:00
jacocoTestReport {
reports {
xml.enabled true
html.enabled true
}
}
check.dependsOn jacocoTestReport
license {
mapping("java", "SLASHSTAR_STYLE")
strictCheck true
ext.year = Calendar.getInstance().get(Calendar.YEAR)
}
[licenseMain, licenseFormatMain].forEach {
it.configure {
include("**/*.java")
exclude("dan200/computercraft/api/**")
header rootProject.file('config/license/main.txt')
}
}
[licenseTest, licenseFormatTest].forEach {
it.configure {
include("**/*.java")
header rootProject.file('config/license/main.txt')
}
}
2019-06-15 11:05:45 +01:00
gradle.projectsEvaluated {
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 rootProject.file('config/license/api.txt')
}
}
2019-06-15 11:05:45 +01:00
// Upload tasks
2019-06-02 16:11:18 +01:00
task checkRelease {
group "upload"
description "Verifies that everything is ready for a release"
inputs.property "version", mod_version
2019-06-02 16:46:45 +01:00
inputs.file("src/main/resources/data/computercraft/lua/rom/help/changelog.txt")
inputs.file("src/main/resources/data/computercraft/lua/rom/help/whatsnew.txt")
doLast {
def ok = true
// Check we're targetting the current version
2019-06-02 16:46:45 +01:00
def whatsnew = new File("src/main/resources/data/computercraft/lua/rom/help/whatsnew.txt").readLines()
if (whatsnew[0] != "New features in CC: Tweaked $mod_version") {
ok = false
project.logger.error("Expected `whatsnew.txt' to target $mod_version.")
}
// Check "read more" exists and trim it
def idx = whatsnew.findIndexOf { it == 'Type "help changelog" to see the full version history.' }
if (idx == -1) {
ok = false
project.logger.error("Must mention the changelog in whatsnew.txt")
} else {
whatsnew = whatsnew.getAt(0 ..< idx)
}
// Check whatsnew and changelog match.
def versionChangelog = "# " + whatsnew.join("\n")
2019-06-02 16:46:45 +01:00
def changelog = new File("src/main/resources/data/computercraft/lua/rom/help/changelog.txt").getText()
if (!changelog.startsWith(versionChangelog)) {
ok = false
project.logger.error("whatsnew and changelog are not in sync")
}
if (!ok) throw new IllegalStateException("Could not check release")
}
}
2019-10-30 17:07:29 +00:00
check.dependsOn checkRelease
2017-12-01 20:05:26 +00:00
curseforge {
apiKey = project.hasProperty('curseForgeApiKey') ? project.curseForgeApiKey : ''
project {
id = '282001'
2020-06-16 09:45:42 +01:00
releaseType = 'release'
2019-04-02 21:33:55 +01:00
changelog = "Release notes can be found on the GitHub repository (https://github.com/SquidDev-CC/CC-Tweaked/releases/tag/v${mc_version}-${mod_version})."
relations {
incompatible "computercraft"
}
2017-12-01 20:05:26 +00:00
}
}
2018-04-19 22:36:00 +01:00
publishing {
publications {
mavenJava(MavenPublication) {
from components.java
2019-04-02 13:27:27 +01:00
// artifact sourceJar
2018-04-19 22:36:00 +01:00
}
}
}
uploadArchives {
repositories {
if(project.hasProperty('mavenUploadUrl')) {
mavenDeployer {
configuration = configurations.deployerJars
2018-04-20 19:39:53 +01:00
2018-04-19 22:36:00 +01:00
repository(url: project.property('mavenUploadUrl')) {
authentication(
userName: project.property('mavenUploadUser'),
privateKey: project.property('mavenUploadKey'))
}
2018-04-20 19:39:53 +01:00
pom.project {
name 'CC: Tweaked'
packaging 'jar'
2019-03-19 11:47:12 +00:00
description 'CC: Tweaked is a fork of ComputerCraft, adding programmable computers, turtles and more to Minecraft.'
2018-04-20 19:39:53 +01:00
url 'https://github.com/SquidDev-CC/CC-Tweaked'
scm {
2019-03-19 11:47:12 +00:00
url 'https://github.com/SquidDev-CC/CC-Tweaked.git'
2018-04-20 19:39:53 +01:00
}
issueManagement {
system 'github'
2019-03-19 11:47:12 +00:00
url 'https://github.com/SquidDev-CC/CC-Tweaked/issues'
2018-04-20 19:39:53 +01:00
}
licenses {
license {
name 'ComputerCraft Public License, Version 1.0'
2019-03-19 11:47:12 +00:00
url 'https://github.com/SquidDev-CC/CC-Tweaked/blob/master/LICENSE'
2018-04-20 19:39:53 +01:00
distribution 'repo'
}
}
}
pom.whenConfigured { pom ->
pom.dependencies.clear()
}
2018-04-19 22:36:00 +01:00
}
}
}
}
2019-04-07 15:30:27 +01:00
githubRelease {
token project.hasProperty('githubApiKey') ? project.githubApiKey : ''
owner 'SquidDev-CC'
repo 'CC-Tweaked'
2019-10-30 17:07:29 +00:00
try {
targetCommitish = Grgit.open(dir: '.').branch.current().name
} catch(Exception ignored) { }
2019-04-07 15:30:27 +01:00
tagName "v${mc_version}-${mod_version}"
releaseName "[${mc_version}] ${mod_version}"
body {
2019-06-02 16:46:45 +01:00
"## " + new File("src/main/resources/data/computercraft/lua/rom/help/whatsnew.txt")
.readLines()
.takeWhile { it != 'Type "help changelog" to see the full version history.' }
.join("\n").trim()
}
2020-06-16 09:45:42 +01:00
prerelease false
2019-04-07 15:30:27 +01:00
}
2019-06-01 09:23:18 +01:00
def uploadTasks = ["uploadArchives", "curseforge", "githubRelease"]
uploadTasks.forEach { tasks.getByName(it).dependsOn checkRelease }
task uploadAll(dependsOn: uploadTasks) {
2019-04-16 10:32:49 +01:00
group "upload"
description "Uploads to all repositories (Maven, Curse, GitHub release)"
}