Merge pull request #2722 from Lucwousin/from-the-gradle-to-the-grave
gradle: Optimizations/cleanup
This commit is contained in:
@@ -4,20 +4,13 @@ import org.gradle.kotlin.dsl.*
|
||||
|
||||
class BootstrapPlugin : Plugin<Project> {
|
||||
override fun apply(project: Project): Unit = with(project) {
|
||||
val clientJar by configurations.creating {
|
||||
isCanBeConsumed = false
|
||||
isCanBeResolved = true
|
||||
isTransitive = false
|
||||
}
|
||||
val bootstrapDependencies by configurations.creating {
|
||||
extendsFrom(clientJar)
|
||||
isCanBeConsumed = false
|
||||
isCanBeResolved = true
|
||||
isTransitive = false
|
||||
}
|
||||
|
||||
dependencies {
|
||||
clientJar(tasks["jar"].outputs.files)
|
||||
bootstrapDependencies(project(":runelite-api"))
|
||||
bootstrapDependencies(project(":runescape-api"))
|
||||
bootstrapDependencies(project(":http-api"))
|
||||
@@ -29,6 +22,9 @@ class BootstrapPlugin : Plugin<Project> {
|
||||
tasks.register<BootstrapTask>("bootstrapStable", "stable")
|
||||
|
||||
tasks.withType<BootstrapTask> {
|
||||
this.group = "openosrs"
|
||||
this.clientJar.fileProvider(provider { tasks["jar"].outputs.files.singleFile })
|
||||
|
||||
dependsOn(bootstrapDependencies)
|
||||
dependsOn("publish")
|
||||
dependsOn(project(":runelite-api").tasks["publish"])
|
||||
@@ -36,8 +32,6 @@ class BootstrapPlugin : Plugin<Project> {
|
||||
dependsOn(project(":http-api").tasks["publish"])
|
||||
dependsOn(project(":injected-client").tasks["publish"])
|
||||
|
||||
this.clientJar = clientJar.singleFile
|
||||
|
||||
doLast {
|
||||
copy {
|
||||
from(bootstrapDependencies)
|
||||
|
||||
@@ -1,9 +1,6 @@
|
||||
import org.gradle.api.DefaultTask
|
||||
import org.gradle.api.tasks.Input
|
||||
import org.gradle.api.tasks.InputFile
|
||||
import org.gradle.api.tasks.PathSensitive
|
||||
import org.gradle.api.tasks.PathSensitivity
|
||||
import org.gradle.api.tasks.TaskAction
|
||||
import org.gradle.api.file.RegularFileProperty
|
||||
import org.gradle.api.tasks.*
|
||||
import org.gradle.kotlin.dsl.extra
|
||||
import org.gradle.kotlin.dsl.get
|
||||
import java.io.File
|
||||
@@ -14,7 +11,7 @@ open class BootstrapTask @Inject constructor(@Input val type: String) : DefaultT
|
||||
|
||||
@InputFile
|
||||
@PathSensitive(PathSensitivity.ABSOLUTE)
|
||||
var clientJar: File? = null
|
||||
val clientJar: RegularFileProperty = project.objects.fileProperty()
|
||||
|
||||
@Input
|
||||
val launcherJvm11Arguments = arrayOf("-XX:+DisableAttachMechanism", "-Drunelite.launcher.nojvm=true", "-Xmx1G", "-Xss2m", "-XX:CompileThreshold=1500", "-Djna.nosys=true")
|
||||
@@ -81,11 +78,12 @@ open class BootstrapTask @Inject constructor(@Input val type: String) : DefaultT
|
||||
}
|
||||
}
|
||||
|
||||
val cjar = clientJar.get().asFile
|
||||
artifacts.add(JsonBuilder(
|
||||
"name" to clientJar!!.name,
|
||||
"path" to "https://github.com/open-osrs/hosting/raw/master/${type}/${clientJar!!.name}",
|
||||
"size" to clientJar!!.length(),
|
||||
"hash" to hash(clientJar!!.readBytes())
|
||||
"name" to cjar.name,
|
||||
"path" to "https://github.com/open-osrs/hosting/raw/master/${type}/${cjar.name}",
|
||||
"size" to cjar.length(),
|
||||
"hash" to hash(cjar.readBytes())
|
||||
))
|
||||
|
||||
return artifacts.toTypedArray()
|
||||
|
||||
@@ -45,7 +45,6 @@ val combined by configurations.creating {
|
||||
configurations {
|
||||
all {
|
||||
isTransitive = false
|
||||
outgoing.artifact(tasks.inject.get().output)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -63,10 +62,8 @@ injector {
|
||||
vanilla.set(vanillaDep.singleFile)
|
||||
}
|
||||
|
||||
sourceSets {
|
||||
main {
|
||||
output.dir(tasks.inject.get().output.get().asFile.parentFile, "builtBy" to tasks.inject)
|
||||
}
|
||||
artifacts {
|
||||
runtimeElements(tasks.inject.get().output)
|
||||
}
|
||||
|
||||
// keep the sourcesets etc but remove useless tasks
|
||||
@@ -83,7 +80,13 @@ tasks {
|
||||
jar {
|
||||
enabled = false
|
||||
}
|
||||
sourcesJar {
|
||||
enabled = false
|
||||
}
|
||||
processResources {
|
||||
enabled = false
|
||||
}
|
||||
assemble {
|
||||
finalizedBy("inject")
|
||||
}
|
||||
}
|
||||
|
||||
@@ -143,7 +143,7 @@ tasks {
|
||||
}
|
||||
|
||||
processResources {
|
||||
dependsOn(":runelite-script-assembler-plugin:indexMojo")
|
||||
dependsOn(":runelite-script-assembler-plugin:assembleMojo")
|
||||
|
||||
from("${buildDir}/scripts")
|
||||
}
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
/*
|
||||
* Copyright (c) 2019 Owain van Brakel <https://github.com/Owain94>
|
||||
* Copyright (c) 2020 Lucas <https://github.com/Lucwousin>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
@@ -22,6 +23,7 @@
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
import java.io.DataOutputStream as DOS
|
||||
|
||||
description = "Script Assembler Plugin"
|
||||
|
||||
@@ -39,34 +41,28 @@ dependencies {
|
||||
|
||||
tasks {
|
||||
register<JavaExec>("assembleMojo") {
|
||||
inputs.files(
|
||||
fileTree("${project.extra["rootPath"]}/runelite-client/src/main/scripts")
|
||||
)
|
||||
|
||||
outputs.dir("${project.extra["rootPath"]}/runelite-client/build/scripts/runelite");
|
||||
outputs.cacheIf { true }
|
||||
val inp = "${project.extra["rootPath"]}/runelite-client/src/main/scripts"
|
||||
val out = "${project.extra["rootPath"]}/runelite-client/build/scripts/runelite"
|
||||
inputs.dir(inp)
|
||||
outputs.dir(out)
|
||||
|
||||
classpath = project.sourceSets.main.get().runtimeClasspath
|
||||
main = "net.runelite.script.AssembleMojo"
|
||||
args(listOf(
|
||||
"${project.extra["rootPath"]}/runelite-client/src/main/scripts",
|
||||
"${project.extra["rootPath"]}/runelite-client/build/scripts/runelite"
|
||||
))
|
||||
}
|
||||
args(listOf(inp, out))
|
||||
|
||||
register<JavaExec>("indexMojo") {
|
||||
inputs.files(
|
||||
fileTree("${project.extra["rootPath"]}/runelite-client/build/scripts/runelite")
|
||||
)
|
||||
|
||||
outputs.file("${project.extra["rootPath"]}/runelite-client/build/scripts/runelite/index");
|
||||
|
||||
dependsOn("assembleMojo")
|
||||
|
||||
classpath = project.sourceSets.main.get().runtimeClasspath
|
||||
main = "net.runelite.script.IndexMojo"
|
||||
args(listOf(
|
||||
"${project.extra["rootPath"]}/runelite-client/build/scripts/runelite",
|
||||
"${project.extra["rootPath"]}/runelite-client/build/scripts/runelite/index"
|
||||
))
|
||||
doLast {
|
||||
DOS(project.file("$out/index").outputStream().buffered(256)).use {
|
||||
project.fileTree(out) {
|
||||
exclude { it.path.endsWith(".hash") || it.name.equals("index") }
|
||||
var lastDir = Int.MAX_VALUE
|
||||
visit {
|
||||
if (this.isDirectory) lastDir = this.name.toInt().shl(16)
|
||||
else it.writeInt(lastDir.or(this.name.toInt()))
|
||||
}
|
||||
}
|
||||
it.writeInt(-1)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,105 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||
* list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package net.runelite.script;
|
||||
|
||||
import java.io.DataOutputStream;
|
||||
import java.io.File;
|
||||
import java.io.FileOutputStream;
|
||||
import java.io.IOException;
|
||||
import static java.lang.Integer.parseInt;
|
||||
import org.apache.maven.plugin.AbstractMojo;
|
||||
import org.apache.maven.plugin.MojoExecutionException;
|
||||
import org.apache.maven.plugin.MojoFailureException;
|
||||
import org.apache.maven.plugins.annotations.LifecyclePhase;
|
||||
import org.apache.maven.plugins.annotations.Mojo;
|
||||
import org.apache.maven.plugins.annotations.Parameter;
|
||||
|
||||
@Mojo(
|
||||
name = "build-index",
|
||||
defaultPhase = LifecyclePhase.GENERATE_RESOURCES
|
||||
)
|
||||
public class IndexMojo extends AbstractMojo
|
||||
{
|
||||
@Parameter(required = true)
|
||||
private File archiveOverlayDirectory;
|
||||
|
||||
@Parameter(required = true)
|
||||
private File indexFile;
|
||||
|
||||
private IndexMojo(File archiveOverlayDirectory, File indexFile)
|
||||
{
|
||||
this.archiveOverlayDirectory = archiveOverlayDirectory;
|
||||
this.indexFile = indexFile;
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws Exception
|
||||
{
|
||||
if (args.length < 2)
|
||||
{
|
||||
throw new IllegalArgumentException("Usage: overlaydir indexfile");
|
||||
}
|
||||
|
||||
File archiveOverlayDirectory = new File(args[0]);
|
||||
File indexFile = new File(args[1]);
|
||||
|
||||
new IndexMojo(archiveOverlayDirectory, indexFile).execute();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void execute() throws MojoExecutionException, MojoFailureException
|
||||
{
|
||||
try (DataOutputStream fout = new DataOutputStream(new FileOutputStream(indexFile)))
|
||||
{
|
||||
for (File indexFolder : archiveOverlayDirectory.listFiles())
|
||||
{
|
||||
if (indexFolder.isDirectory())
|
||||
{
|
||||
int indexId = parseInt(indexFolder.getName());
|
||||
for (File archiveFile : indexFolder.listFiles())
|
||||
{
|
||||
int archiveId;
|
||||
try
|
||||
{
|
||||
archiveId = parseInt(archiveFile.getName());
|
||||
}
|
||||
catch (NumberFormatException ex)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
fout.writeInt(indexId << 16 | archiveId);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fout.writeInt(-1);
|
||||
}
|
||||
catch (IOException ex)
|
||||
{
|
||||
throw new MojoExecutionException("error building index file", ex);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -29,6 +29,13 @@ plugins {
|
||||
id("com.gradle.enterprise").version("3.0")
|
||||
}
|
||||
|
||||
gradleEnterprise {
|
||||
buildScan {
|
||||
termsOfServiceUrl = "https://gradle.com/terms-of-service"
|
||||
termsOfServiceAgree = System.getenv("SCAN_TOS_ACCEPTED")?: "no"
|
||||
}
|
||||
}
|
||||
|
||||
include(":http-api")
|
||||
include(":cache")
|
||||
include(":runelite-api")
|
||||
|
||||
Reference in New Issue
Block a user