Compare commits

..

No commits in common. "master" and "v2.5.5" have entirely different histories.

6 changed files with 56 additions and 57 deletions

View File

@ -1,43 +1,15 @@
import io.gitlab.jfronny.scripts.*
plugins { plugins {
id("jfmod") version "1.6-SNAPSHOT" id("jfmod") version "1.3-SNAPSHOT"
}
allprojects { group = "io.gitlab.jfronny" }
base.archivesName = "modsmod"
val commonsVersion = "2.0.0-SNAPSHOT"
jfMod {
minecraftVersion = "1.21"
yarn("build.1")
loaderVersion = "0.15.11"
libJfVersion = "3.16.0"
fabricApiVersion = "0.100.1+1.21"
modrinth {
projectId = "modsmod"
requiredDependencies.add("libjf")
optionalDependencies.add("modmenu")
}
curseforge {
projectId = "405095"
requiredDependencies.add("libjf")
optionalDependencies.add("modmenu")
}
} }
dependencies { dependencies {
modImplementation("io.gitlab.jfronny.libjf:libjf-config-core-v2") modImplementation("io.gitlab.jfronny.libjf:libjf-config-core-v1:${prop("libjf_version")}")
modImplementation("io.gitlab.jfronny.libjf:libjf-unsafe-v0") modImplementation("io.gitlab.jfronny.libjf:libjf-unsafe-v0:${prop("libjf_version")}")
compileOnly("io.gitlab.jfronny:commons-serialize-generator-annotations:$commonsVersion")
annotationProcessor("io.gitlab.jfronny:commons-serialize-generator:$commonsVersion")
// Dev env // Dev env
modLocalRuntime("io.gitlab.jfronny.libjf:libjf-config-ui-tiny") modLocalRuntime("io.gitlab.jfronny.libjf:libjf-config-ui-tiny-v1:${prop("libjf_version")}")
modLocalRuntime("io.gitlab.jfronny.libjf:libjf-devutil") modLocalRuntime("io.gitlab.jfronny.libjf:libjf-devutil:${prop("libjf_version")}")
modLocalRuntime("com.terraformersmc:modmenu:11.0.0-beta.1") modLocalRuntime("com.terraformersmc:modmenu:7.0.1")
// for modmenu
modLocalRuntime("net.fabricmc.fabric-api:fabric-resource-loader-v0")
modLocalRuntime("net.fabricmc.fabric-api:fabric-screen-api-v1")
modLocalRuntime("net.fabricmc.fabric-api:fabric-key-binding-api-v1")
} }

17
gradle.properties Normal file
View File

@ -0,0 +1,17 @@
# https://fabricmc.net/develop/
minecraft_version=1.20
yarn_mappings=build.1
loader_version=0.14.21
maven_group=io.gitlab.jfronny
archives_base_name=modsmod
modrinth_id=modsmod
modrinth_required_dependencies=libjf
modrinth_optional_dependencies=modmenu
curseforge_id=405095
curseforge_required_dependencies=libjf
curseforge_optional_dependencies=modmenu
libjf_version=3.8.0
fabric_version=0.83.0+1.20

View File

@ -1,13 +1,15 @@
package io.gitlab.jfronny.modsmod; package io.gitlab.jfronny.modsmod;
import io.gitlab.jfronny.commons.serialize.databind.api.TypeToken; import io.gitlab.jfronny.gson.reflect.TypeToken;
import io.gitlab.jfronny.modsmod.util.IteratorCallbackList; import io.gitlab.jfronny.modsmod.util.IteratorCallbackList;
import net.fabricmc.loader.impl.FabricLoaderImpl; import net.fabricmc.loader.impl.FabricLoaderImpl;
import net.fabricmc.loader.impl.ModContainerImpl; import net.fabricmc.loader.impl.ModContainerImpl;
import net.fabricmc.loader.impl.discovery.ModCandidate; import net.fabricmc.loader.impl.discovery.ModCandidate;
import net.fabricmc.loader.impl.metadata.LoaderModMetadata; import net.fabricmc.loader.impl.metadata.LoaderModMetadata;
import java.lang.reflect.*; import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Collection; import java.util.Collection;
import java.util.List; import java.util.List;

View File

@ -1,26 +1,31 @@
package io.gitlab.jfronny.modsmod; package io.gitlab.jfronny.modsmod;
import io.gitlab.jfronny.commons.logger.SystemLoggerPlus; import io.gitlab.jfronny.commons.log.*;
import io.gitlab.jfronny.libjf.config.api.v2.ConfigInstance; import io.gitlab.jfronny.gson.Gson;
import io.gitlab.jfronny.libjf.config.api.v1.ConfigInstance;
import io.gitlab.jfronny.libjf.unsafe.UltraEarlyInit; import io.gitlab.jfronny.libjf.unsafe.UltraEarlyInit;
import io.gitlab.jfronny.modsmod.builder.JsonBuilder; import io.gitlab.jfronny.modsmod.builder.JsonBuilder;
import io.gitlab.jfronny.modsmod.builder.ModMeta; import io.gitlab.jfronny.modsmod.builder.ModMeta;
import io.gitlab.jfronny.modsmod.util.IOUtil; import io.gitlab.jfronny.modsmod.util.IOUtil;
import net.fabricmc.loader.api.FabricLoader; import net.fabricmc.loader.api.*;
import net.fabricmc.loader.impl.FabricLoaderImpl; import net.fabricmc.loader.impl.FabricLoaderImpl;
import net.fabricmc.loader.impl.metadata.*; import net.fabricmc.loader.impl.metadata.*;
import net.fabricmc.loader.impl.util.FileSystemUtil; import net.fabricmc.loader.impl.util.FileSystemUtil;
import java.io.IOException; import java.io.IOException;
import java.nio.file.*; import java.nio.file.FileSystem;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardCopyOption;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashSet; import java.util.HashSet;
public class ModsMod implements UltraEarlyInit { public class ModsMod implements UltraEarlyInit {
static final HashSet<ModMeta> MODS = new HashSet<>(); static final HashSet<ModMeta> MODS = new HashSet<>();
static final FabricLoaderImpl LOADER = FabricLoaderImpl.INSTANCE; static final FabricLoaderImpl LOADER = FabricLoaderImpl.INSTANCE;
public static final Gson GSON = new Gson();
public static final String MOD_ID = "modsmod"; public static final String MOD_ID = "modsmod";
public static final SystemLoggerPlus LOGGER = SystemLoggerPlus.forName(MOD_ID); public static final Logger LOGGER = Logger.forName(MOD_ID);
private static final String CACHE_NAME = MOD_ID + "cache"; private static final String CACHE_NAME = MOD_ID + "cache";
@Override @Override

View File

@ -1,7 +1,7 @@
package io.gitlab.jfronny.modsmod; package io.gitlab.jfronny.modsmod;
import io.gitlab.jfronny.libjf.config.api.v2.Entry; import io.gitlab.jfronny.libjf.config.api.v1.JfConfig;
import io.gitlab.jfronny.libjf.config.api.v2.JfConfig; import io.gitlab.jfronny.libjf.config.api.v1.Entry;
@JfConfig @JfConfig
public class ModsModConfig { public class ModsModConfig {

View File

@ -1,8 +1,5 @@
package io.gitlab.jfronny.modsmod.builder; package io.gitlab.jfronny.modsmod.builder;
import io.gitlab.jfronny.commons.serialize.generator.annotations.GPrefer;
import io.gitlab.jfronny.commons.serialize.generator.annotations.GSerializable;
import io.gitlab.jfronny.libjf.LibJf;
import io.gitlab.jfronny.modsmod.ModsMod; import io.gitlab.jfronny.modsmod.ModsMod;
import java.io.BufferedWriter; import java.io.BufferedWriter;
@ -15,21 +12,27 @@ import java.util.Map;
public class JsonBuilder { public class JsonBuilder {
public static void build(int number, Path outputPath, boolean parent) throws IOException { public static void build(int number, Path outputPath, boolean parent) throws IOException {
try (BufferedWriter bw = Files.newBufferedWriter(outputPath)) { try (BufferedWriter bw = Files.newBufferedWriter(outputPath)) {
GC_JsonBuilder.ModManifest.serialize(new ModManifest(number, parent), bw, LibJf.JSON_TRANSPORT); ModsMod.GSON.toJson(new ModManifest(number, parent), bw);
} }
} }
@GSerializable @SuppressWarnings("unused")
public record ModManifest(int schemaVersion, String id, String version, String name, Map<String, ModMenuData> custom) { private static class ModManifest {
@GPrefer public final int schemaVersion = 1;
public ModManifest { public final String id;
} public final String version = "1.0";
public final String name;
public final Map<String, ModMenuData> custom = new HashMap<>();
public ModManifest(int number, boolean parent) { public ModManifest(int number, boolean parent) {
this(1, "modmod_" + number, "1.0", "ModsMod " + number, parent ? Map.of("modmenu", new ModMenuData("modsmod")) : Map.of()); id = "modmod_" + number;
name = "ModsMod " + number;
if (parent)
custom.put("modmenu", new ModMenuData());
} }
@GSerializable public static class ModMenuData {
public record ModMenuData(String parent) { } public final String parent = "modsmod";
}
} }
} }