-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathroot.gradle.kts
62 lines (54 loc) · 2 KB
/
root.gradle.kts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/*
* Copyright (c) 2024 ModCore Inc. All rights reserved.
*
* This code is part of ModCore Inc.'s Essential Mod repository and is protected
* under copyright registration # TX0009138511. For the full license, see:
* https://github.com/EssentialGG/Essential/blob/main/LICENSE
*
* You may not use, copy, reproduce, modify, sell, license, distribute,
* commercialize, or otherwise exploit, or create derivative works based
* upon, this file or any other in this repository, all of which is reserved by Essential.
*/
import essential.*
import gg.essential.gradle.util.*
import net.fabricmc.loom.task.RemapJarTask
plugins {
id("base")
id("essential.utils")
id("gg.essential.multi-version.root") version "0.2.2"
}
if (version == "unspecified") {
version = versionFromBuildIdAndBranch()
if ("-SNAPSHOT" !in version.toString()) version = version.toString() + "+g" + commit()
}
fun commit(): String = try {
val stdout = java.io.ByteArrayOutputStream()
exec {
commandLine("git", "rev-parse", "HEAD")
standardOutput = stdout
}
stdout.toString().trim().slice(0 until 10)
} catch (e: Throwable) {
"unknown"
}
configurePreprocessTree(file("versions"))
// Workaround for https://github.com/gradle/gradle/issues/4823
project(":api").subprojects.forEach { it.evaluationDependsOn(":api") }
// remapJar tasks can eat quite a lot of RAM if many are ran in parallel.
// TODO: This has only become an issue with Loom 1.2, maybe it's a bug?
// This shared service serves as a way to limit that.
abstract class LimitedConcurrentRemapService : BuildService<BuildServiceParameters.None>
val concurrentRemapLimit = gradle.sharedServices.registerIfAbsent("concurrentRemapLimit", LimitedConcurrentRemapService::class.java) {
maxParallelUsages.set(4)
}
allprojects {
tasks.withType<RemapJarTask> {
usesService(concurrentRemapLimit)
}
}
allprojects {
tasks.withType<AbstractArchiveTask> {
isPreserveFileTimestamps = false
isReproducibleFileOrder = true
}
}