Respackopts/src/main/java/io/gitlab/jfronny/respackopts/Respackopts.java

210 lines
8.7 KiB
Java
Raw Normal View History

2020-11-24 22:04:13 +01:00
package io.gitlab.jfronny.respackopts;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import io.gitlab.jfronny.respackopts.integration.FrexCompat;
2021-11-14 15:37:01 +01:00
import io.gitlab.jfronny.respackopts.model.*;
import io.gitlab.jfronny.respackopts.model.condition.Condition;
import io.gitlab.jfronny.respackopts.model.enums.ConfigSyncMode;
import io.gitlab.jfronny.respackopts.model.enums.PackCapability;
2021-09-15 16:45:54 +02:00
import io.gitlab.jfronny.respackopts.filters.DirFilterEventImpl;
import io.gitlab.jfronny.respackopts.gson.*;
import io.gitlab.jfronny.respackopts.gson.entry.BooleanEntrySerializer;
import io.gitlab.jfronny.respackopts.gson.entry.ConfigBranchSerializer;
import io.gitlab.jfronny.respackopts.gson.entry.EnumEntrySerializer;
import io.gitlab.jfronny.respackopts.gson.entry.NumericEntrySerializer;
import io.gitlab.jfronny.respackopts.util.RpoCommand;
2021-11-14 15:37:01 +01:00
import io.gitlab.jfronny.respackopts.model.tree.*;
2021-09-15 16:45:54 +02:00
import io.gitlab.jfronny.respackopts.filters.FileFilterEventImpl;
import io.gitlab.jfronny.respackopts.util.GuiFactory;
import meteordevelopment.starscript.Script;
2021-08-24 17:42:46 +02:00
import meteordevelopment.starscript.StandardLib;
import meteordevelopment.starscript.Starscript;
2020-11-24 22:04:13 +01:00
import net.fabricmc.api.ClientModInitializer;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.fabricmc.loader.api.FabricLoader;
2021-10-09 13:09:57 +02:00
import net.fabricmc.loader.impl.gui.FabricGuiEntry;
2021-08-24 17:42:46 +02:00
import net.minecraft.client.MinecraftClient;
import net.minecraft.resource.ResourcePack;
2021-08-24 17:42:46 +02:00
import net.minecraft.server.integrated.IntegratedServer;
2021-06-10 13:10:12 +02:00
import net.minecraft.util.Identifier;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
2020-11-24 22:04:13 +01:00
2021-06-10 16:11:19 +02:00
import java.io.IOException;
import java.io.Reader;
import java.io.Writer;
2020-11-24 22:04:13 +01:00
import java.nio.file.Files;
import java.nio.file.Path;
2021-06-10 16:11:19 +02:00
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
2021-08-24 17:42:46 +02:00
import java.util.concurrent.CompletableFuture;
2020-11-24 22:04:13 +01:00
@Environment(EnvType.CLIENT)
public class Respackopts implements ClientModInitializer {
2021-06-10 13:10:12 +02:00
public static final Map<String, ConfigBranch> CONFIG_BRANCH = new HashMap<>();
public static final Map<String, PackMeta> PACK_METAS = new HashMap<>();
public static final Map<String, String> DISPLAY_NAME_LOOKUP = new HashMap<>();
public static final Map<String, String> PACK_NAME_LOOKUP = new HashMap<>();
public static final Integer META_VERSION = 6;
public static final String FILE_EXTENSION = ".rpo";
public static final Gson GSON;
2021-06-10 13:10:12 +02:00
2021-08-24 17:42:46 +02:00
public static Starscript STAR_SCRIPT;
public static final String ID = "respackopts";
public static final Logger LOGGER = LogManager.getFormatterLogger(ID);
public static final Identifier CONF_ID = new Identifier(ID, "conf.json");
2021-09-15 18:37:07 +02:00
public static final Set<Runnable> SAVE_ACTIONS = new HashSet<>();
public static final GuiFactory GUI_FACTORY = new GuiFactory();
2021-08-24 17:42:46 +02:00
2021-09-15 16:45:54 +02:00
public static boolean forcePackReload = false;
public static Path CONF_DIR;
public static ConfigFile CONFIG;
2021-10-03 19:26:26 +02:00
public static final Identifier RPO_SHADER_ID = new Identifier(Respackopts.ID, "config_supplier");
private static String shaderImportSource;
2021-06-10 13:10:12 +02:00
static {
GSON = new GsonBuilder()
.registerTypeAdapter(ConfigEnumEntry.class, new EnumEntrySerializer())
.registerTypeAdapter(ConfigNumericEntry.class, new NumericEntrySerializer())
.registerTypeAdapter(ConfigBooleanEntry.class, new BooleanEntrySerializer())
.registerTypeAdapter(ConfigBranch.class, new ConfigBranchSerializer())
.registerTypeAdapter(Script.class, new ScriptDeserializer())
.registerTypeAdapter(FileRpo.class, new FileRpoDeserializer())
.registerTypeAdapter(DirRpo.class, new DirRpoDeserializer())
.registerTypeAdapter(Condition.class, new ConditionDeserializer())
2021-10-21 18:45:31 +02:00
.registerTypeAdapterFactory(new SingleEntrySetTypeAdapterFactory())
.registerTypeAdapterFactory(new SingleEntryListTypeAdapterFactory())
.setPrettyPrinting()
.create();
2021-08-24 17:42:46 +02:00
try {
CONF_DIR = FabricLoader.getInstance().getConfigDir().resolve(ID);
CONFIG = ConfigFile.load();
2021-08-24 17:42:46 +02:00
} catch (Throwable e) {
LOGGER.error("Could not resolve config directory", e);
}
try {
STAR_SCRIPT = new Starscript();
} catch (Exception e) {
2021-08-24 17:42:46 +02:00
FabricGuiEntry.displayCriticalError(new Exception("Respackopts could not initialize Starscript. Expect issues with packs that use it", e), false);
}
StandardLib.init(STAR_SCRIPT);
2021-06-10 13:10:12 +02:00
}
public static String getId(ResourcePack pack) {
return PACK_NAME_LOOKUP.get(pack.getName());
}
public static boolean hasCapability(ResourcePack pack, PackCapability capability) {
String id = getId(pack);
if (id == null) return false;
return PACK_METAS.get(id).capabilities.contains(capability);
}
2020-11-24 22:04:13 +01:00
@Override
public void onInitializeClient() {
try {
Files.createDirectories(CONF_DIR);
} catch (IOException e) {
LOGGER.error("Could not initialize config directory", e);
}
if (CONFIG.debugLogs)
SAVE_ACTIONS.add(() -> LOGGER.info("Save"));
2021-08-24 17:42:46 +02:00
SAVE_ACTIONS.add(() -> {
for (Map.Entry<String, ConfigBranch> e : CONFIG_BRANCH.entrySet()) {
STAR_SCRIPT.set(sanitizeString(e.getKey()), () -> e.getValue().buildStarscript());
}
});
2021-10-03 19:26:26 +02:00
SAVE_ACTIONS.add(() -> {
if (CONFIG.debugLogs)
LOGGER.info("Generating shader code");
2021-10-03 19:26:26 +02:00
StringBuilder sb = new StringBuilder();
sb.append("#ifndef respackopts_loaded");
sb.append("\n#define respackopts_loaded");
2021-10-03 19:26:26 +02:00
for (Map.Entry<String, ConfigBranch> e : CONFIG_BRANCH.entrySet()) {
e.getValue().buildShader(sb, sanitizeString(e.getKey()));
}
sb.append("\n#endif");
2021-10-03 19:26:26 +02:00
shaderImportSource = sb.toString();
});
2021-09-15 16:45:54 +02:00
DirFilterEventImpl.init();
FileFilterEventImpl.init();
if (CONFIG.debugCommands)
2021-09-15 18:37:07 +02:00
RpoCommand.register();
if (FabricLoader.getInstance().isModLoaded("frex")) {
FrexCompat.onInitializeFrex();
}
}
public static void save() {
if (CONFIG.debugLogs)
LOGGER.info("Saving configs");
for (Map.Entry<String, ConfigBranch> e : CONFIG_BRANCH.entrySet()) {
try (Writer writer = Files.newBufferedWriter(CONF_DIR.resolve(e.getKey() + ".json"))) {
GSON.toJson(e.getValue(), writer);
writer.flush();
} catch (IOException ex) {
LOGGER.error("Could not save config", ex);
}
}
2021-06-10 13:10:12 +02:00
for (Runnable action : SAVE_ACTIONS) {
action.run();
}
}
public static void load(String id) {
Path q = CONF_DIR.resolve(id + ".json");
if (Files.exists(q)) {
if (CONFIG.debugLogs)
LOGGER.info("Loading configs for: " + id);
2021-06-10 13:10:12 +02:00
try (Reader reader = Files.newBufferedReader(q)) {
ConfigBranch b = GSON.fromJson(reader, ConfigBranch.class);
2021-06-10 13:10:12 +02:00
if (CONFIG_BRANCH.containsKey(id))
CONFIG_BRANCH.get(id).sync(b, ConfigSyncMode.CONF_LOAD);
2021-08-24 17:42:46 +02:00
STAR_SCRIPT.set(sanitizeString(id), b::buildStarscript);
2021-06-10 14:55:03 +02:00
} catch (IOException e) {
LOGGER.error("Failed to load " + id, e);
}
}
}
public static String sanitizeString(String s) {
// This trims whitespace/underscores and removes non-alphabetical or underscore characters
// ^ = start of string
// $ = end of string
// * = zero or more times
// [\\s_] = whitespace or underscores
// | = or
// [^a-zA-Z_] = not character or underscore
return s.replaceAll("[^a-zA-Z_]|^[\\s_]*|[\\s_]*$", "");
}
2021-08-24 17:42:46 +02:00
public static CompletableFuture<Void> forceReloadResources() {
if (CONFIG.debugLogs)
LOGGER.info("Forcing resource reload");
2021-08-24 17:42:46 +02:00
return CompletableFuture.allOf(MinecraftClient.getInstance().reloadResources(),
reloadData());
}
public static CompletableFuture<Void> reloadData() {
IntegratedServer is = MinecraftClient.getInstance().getServer();
if (is != null) {
is.getDataPackManager().scanPacks();
return is.reloadResources(is.getDataPackManager().getEnabledNames());
}
return CompletableFuture.completedFuture(null);
}
2021-10-03 19:26:26 +02:00
public static String getShaderImportSource() {
if (shaderImportSource == null) {
Respackopts.LOGGER.error("Shader import source is null");
return "";
}
return shaderImportSource;
}
2020-11-24 22:04:13 +01:00
}