From a1b69c4d7402012e15bb701542fa99f454696ad5 Mon Sep 17 00:00:00 2001 From: EpicKnarvik97 Date: Sat, 6 Sep 2025 01:59:35 +0200 Subject: [PATCH] Adds a custom plugin implementation that uses the StargateYamlConfiguration --- .../knarlib/plugin/ConfigCommentPlugin.java | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/main/java/net/knarcraft/knarlib/plugin/ConfigCommentPlugin.java diff --git a/src/main/java/net/knarcraft/knarlib/plugin/ConfigCommentPlugin.java b/src/main/java/net/knarcraft/knarlib/plugin/ConfigCommentPlugin.java new file mode 100644 index 0000000..48c31d7 --- /dev/null +++ b/src/main/java/net/knarcraft/knarlib/plugin/ConfigCommentPlugin.java @@ -0,0 +1,38 @@ +package net.knarcraft.knarlib.plugin; + +import net.knarcraft.knarlib.config.StargateYamlConfiguration; +import org.bukkit.configuration.file.FileConfiguration; +import org.bukkit.plugin.Plugin; +import org.jetbrains.annotations.NotNull; + +/** + * A plugin that uses a Stargate YAML configuration in order to retain all configuration comments + */ +@SuppressWarnings("unused") +public abstract class ConfigCommentPlugin implements Plugin { + + protected StargateYamlConfiguration configuration = null; + + @Override + public void reloadConfig() { + this.configuration = StargateYamlConfiguration.loadConfiguration(this, true); + } + + @Override + public void saveConfig() { + if (this.configuration == null) { + this.reloadConfig(); + } + StargateYamlConfiguration.saveConfiguration(this, this.configuration); + } + + @Override + @NotNull + public FileConfiguration getConfig() { + if (this.configuration == null) { + this.reloadConfig(); + } + return this.configuration; + } + +}