Compare commits
No commits in common. "0484769372127d622e2a1e1eed95b6747e4ec16f" and "2ef8b2d1be212dc11cafac1febe100d10a90d3f5" have entirely different histories.
0484769372
...
2ef8b2d1be
2 changed files with 1 additions and 32 deletions
|
|
@ -90,40 +90,12 @@ tasks.register("buildAll") {
|
|||
dependsOn(tasks.withType<Jar>())
|
||||
}
|
||||
|
||||
// Task to merge service files
|
||||
val prepareServiceFiles = tasks.register("prepareServiceFiles") {
|
||||
val outputDir = layout.buildDirectory.dir("generated/service-files")
|
||||
val serviceFile = "META-INF/services/org.adrianvictor.lib.versioning.VersionedServiceRegistrar"
|
||||
|
||||
// Define inputs
|
||||
val inputFiles = mcVersions.map { ver -> file("src/$ver/resources/$serviceFile") }.filter { it.exists() }
|
||||
inputs.files(inputFiles)
|
||||
outputs.dir(outputDir)
|
||||
|
||||
doLast {
|
||||
val registrars = mutableSetOf<String>()
|
||||
inputFiles.forEach { file ->
|
||||
registrars.addAll(file.readLines().filter { it.isNotBlank() })
|
||||
}
|
||||
|
||||
val mergedFile = outputDir.get().file(serviceFile).asFile
|
||||
mergedFile.parentFile.mkdirs()
|
||||
mergedFile.writeText(registrars.joinToString("\n"))
|
||||
}
|
||||
}
|
||||
|
||||
tasks.register<Jar>("bundleAll") {
|
||||
from(sourceSets["main"].output)
|
||||
mcVersions.forEach { ver ->
|
||||
from(sourceSets[ver].output)
|
||||
}
|
||||
|
||||
// Include the merged service file
|
||||
from(prepareServiceFiles) {
|
||||
into("META-INF/services")
|
||||
include("org.adrianvictor.lib.versioning.VersionedServiceRegistrar")
|
||||
}
|
||||
|
||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||
|
||||
archiveClassifier.set("all-implementations")
|
||||
|
|
|
|||
|
|
@ -19,13 +19,10 @@ public class Main extends JavaPlugin {
|
|||
|
||||
versionedServiceFactory = new DefaultVersionedServiceFactory(versionMatcher);
|
||||
|
||||
ServiceLoader<VersionedServiceRegistrar> registrars = ServiceLoader.load(VersionedServiceRegistrar.class, getClassLoader());
|
||||
int count = 0;
|
||||
ServiceLoader<VersionedServiceRegistrar> registrars = ServiceLoader.load(VersionedServiceRegistrar.class);
|
||||
for (VersionedServiceRegistrar registrar : registrars) {
|
||||
registrar.register(versionedServiceFactory);
|
||||
count++;
|
||||
}
|
||||
getLogger().info("Registered " + count + " version-specific registrars.");
|
||||
|
||||
getLogger().info("tenkumaLib has been enabled!");
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue