From 5c0f7dba3bb13632e66c61f07a95b641dfec04af Mon Sep 17 00:00:00 2001 From: NekoMonci12 Date: Thu, 8 May 2025 20:39:32 +0700 Subject: [PATCH] Logging System --- src/main/java/org/yuemi/feather/Main.java | 17 +++---- .../yuemi/feather/functions/LoggerUtil.java | 45 +++++++++++++++++++ 2 files changed, 54 insertions(+), 8 deletions(-) create mode 100644 src/main/java/org/yuemi/feather/functions/LoggerUtil.java diff --git a/src/main/java/org/yuemi/feather/Main.java b/src/main/java/org/yuemi/feather/Main.java index f525a5a..8ccddb2 100644 --- a/src/main/java/org/yuemi/feather/Main.java +++ b/src/main/java/org/yuemi/feather/Main.java @@ -1,4 +1,4 @@ -package org.yuemi.yuelicenser; +package org.yuemi.feather; // Bukkit import org.bukkit.Bukkit; @@ -9,21 +9,22 @@ import org.bukkit.event.EventHandler; // PlaceholderAPI //import me.clip.placeholderapi.PlaceholderAPI; //import me.clip.placeholderapi.expansion.PlaceholderExpansion; +// YueMi +import org.yuemi.feather.functions.LoggerUtil; public class Main extends JavaPlugin { - public enum LogType { - NONE, LOW, MEDIUM, HIGH - } - private LogType logType = LogType.LOW; + String pluginName = getDescription().getName(); + + @Override public void onEnable() { - // Save the default config if it doesn't exist yet - saveDefaultConfig(); + saveDefaultConfig(); // Save the default config if it doesn't exist yet + LoggerUtil.logs(1, "Enabling " + pluginName); } @Override public void onDisable() { - // Implement Here + LoggerUtil.logs(1, "Disabling " + pluginName); } } \ No newline at end of file diff --git a/src/main/java/org/yuemi/feather/functions/LoggerUtil.java b/src/main/java/org/yuemi/feather/functions/LoggerUtil.java new file mode 100644 index 0000000..61e880e --- /dev/null +++ b/src/main/java/org/yuemi/feather/functions/LoggerUtil.java @@ -0,0 +1,45 @@ +package org.yuemi.feather.functions; + +import org.bukkit.Bukkit; +import org.bukkit.ChatColor; + +/** + * Simple logger with numeric level input + */ +public class LoggerUtil { + + /** + * Log message with numeric level: + * 1 = INFO, 2 = WARNING, 3 = ERROR, 4 = DEBUG + */ + public static void logs(int level, Object message) { + String msg = message.toString(); + + String prefix = "[FeatherUtils]"; + String formattedMessage; + + switch (level) { + case 1: // INFO + formattedMessage = String.format("%s %s%s", prefix, ChatColor.GREEN, msg); + Bukkit.getLogger().info(formattedMessage); + break; + case 2: // WARNING + formattedMessage = String.format("%s %s%s", prefix, ChatColor.YELLOW, msg); + Bukkit.getLogger().warning(formattedMessage); + break; + case 3: // ERROR + formattedMessage = String.format("%s %s%s", prefix, ChatColor.RED, msg); + Bukkit.getLogger().severe(formattedMessage); + break; + case 4: // DEBUG + formattedMessage = String.format("%s %s%s", prefix, ChatColor.GRAY, msg); + Bukkit.getLogger().info(formattedMessage); + break; + default: + // fallback to info if level wrong + formattedMessage = String.format("%s %s%s", prefix, ChatColor.GREEN, msg); + Bukkit.getLogger().info(formattedMessage); + break; + } + } +} \ No newline at end of file