Generate fabric.mod.json for included submodule jars (#343)
* Generate fabric.mod.json for included submodule jars * Appease checkstyle
This commit is contained in:
parent
5b3222e9b9
commit
671328795e
1 changed files with 65 additions and 10 deletions
|
@ -29,6 +29,7 @@ import java.io.IOException;
|
|||
import java.nio.file.Path;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Locale;
|
||||
|
@ -118,9 +119,19 @@ public class NestedJars {
|
|||
|
||||
for (Task task : remapJarTasks.isEmpty() ? jarTasks : remapJarTasks) {
|
||||
if (task instanceof RemapJarTask) {
|
||||
fileList.add(((RemapJarTask) task).getArchivePath());
|
||||
fileList.addAll(prepareForNesting(
|
||||
Collections.singleton(((RemapJarTask) task).getArchivePath()),
|
||||
projectDependency,
|
||||
new ProjectDependencyMetaExtractor(),
|
||||
project
|
||||
));
|
||||
} else if (task instanceof AbstractArchiveTask) {
|
||||
fileList.add(((AbstractArchiveTask) task).getArchivePath());
|
||||
fileList.addAll(prepareForNesting(
|
||||
Collections.singleton(((AbstractArchiveTask) task).getArchivePath()),
|
||||
projectDependency,
|
||||
new ProjectDependencyMetaExtractor(),
|
||||
project
|
||||
));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -136,8 +147,10 @@ public class NestedJars {
|
|||
.stream()
|
||||
.map(ResolvedArtifact::getFile)
|
||||
.collect(Collectors.toSet()),
|
||||
dependency, project)
|
||||
);
|
||||
dependency,
|
||||
new ResolvedDependencyMetaExtractor(),
|
||||
project
|
||||
));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -178,7 +191,7 @@ public class NestedJars {
|
|||
}
|
||||
|
||||
//This is a good place to do pre-nesting operations, such as adding a fabric.mod.json to a library
|
||||
private static List<File> prepareForNesting(Set<File> files, ResolvedDependency dependency, Project project) {
|
||||
private static <D> List<File> prepareForNesting(Set<File> files, D dependency, DependencyMetaExtractor<D> metaExtractor, Project project) {
|
||||
List<File> fileList = new ArrayList<>();
|
||||
|
||||
for (File file : files) {
|
||||
|
@ -203,7 +216,7 @@ public class NestedJars {
|
|||
throw new RuntimeException("Failed to copy file", e);
|
||||
}
|
||||
|
||||
ZipUtil.addEntry(tempFile, "fabric.mod.json", getMod(dependency).getBytes());
|
||||
ZipUtil.addEntry(tempFile, "fabric.mod.json", getMod(dependency, metaExtractor).getBytes());
|
||||
fileList.add(tempFile);
|
||||
} else {
|
||||
// Default copy the jar right in
|
||||
|
@ -215,12 +228,12 @@ public class NestedJars {
|
|||
}
|
||||
|
||||
// Generates a barebones mod for a dependency
|
||||
private static String getMod(ResolvedDependency dependency) {
|
||||
private static <D> String getMod(D dependency, DependencyMetaExtractor<D> metaExtractor) {
|
||||
JsonObject jsonObject = new JsonObject();
|
||||
jsonObject.addProperty("schemaVersion", 1);
|
||||
jsonObject.addProperty("id", (dependency.getModuleGroup() + "_" + dependency.getModuleName()).replaceAll("\\.", "_").toLowerCase(Locale.ENGLISH));
|
||||
jsonObject.addProperty("version", dependency.getModuleVersion());
|
||||
jsonObject.addProperty("name", dependency.getModuleName());
|
||||
jsonObject.addProperty("id", (metaExtractor.group(dependency) + "_" + metaExtractor.name(dependency)).replaceAll("\\.", "_").toLowerCase(Locale.ENGLISH));
|
||||
jsonObject.addProperty("version", metaExtractor.version(dependency));
|
||||
jsonObject.addProperty("name", metaExtractor.name(dependency));
|
||||
|
||||
JsonObject custom = new JsonObject();
|
||||
custom.addProperty("fabric-loom:generated", true);
|
||||
|
@ -232,4 +245,46 @@ public class NestedJars {
|
|||
private static ZipEntryTransformerEntry[] single(ZipEntryTransformerEntry element) {
|
||||
return new ZipEntryTransformerEntry[]{element};
|
||||
}
|
||||
|
||||
private interface DependencyMetaExtractor<D> {
|
||||
String group(D dependency);
|
||||
|
||||
String version(D dependency);
|
||||
|
||||
String name(D dependency);
|
||||
}
|
||||
|
||||
private static final class ProjectDependencyMetaExtractor implements DependencyMetaExtractor<ProjectDependency> {
|
||||
@Override
|
||||
public String group(ProjectDependency dependency) {
|
||||
return dependency.getGroup();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String version(ProjectDependency dependency) {
|
||||
return dependency.getVersion();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String name(ProjectDependency dependency) {
|
||||
return dependency.getName();
|
||||
}
|
||||
}
|
||||
|
||||
private static final class ResolvedDependencyMetaExtractor implements DependencyMetaExtractor<ResolvedDependency> {
|
||||
@Override
|
||||
public String group(ResolvedDependency dependency) {
|
||||
return dependency.getModuleGroup();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String version(ResolvedDependency dependency) {
|
||||
return dependency.getModuleVersion();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String name(ResolvedDependency dependency) {
|
||||
return dependency.getModuleName();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue