/* * This file is a part of the SteamWar software. * * Copyright (C) 2021 SteamWar.de-Serverteam * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ package de.steamwar.bausystem; import de.steamwar.bausystem.config.ColorConfig; import de.steamwar.bausystem.linkage.LinkageUtils; import de.steamwar.bausystem.region.loader.PrototypeLoader; import de.steamwar.bausystem.region.loader.RegionLoader; import de.steamwar.bausystem.region.loader.Updater; import lombok.Getter; import org.bukkit.Bukkit; import org.bukkit.event.Listener; import org.bukkit.plugin.java.JavaPlugin; import java.io.IOException; import java.io.OutputStream; import java.io.PrintStream; import java.util.logging.Level; public class BauSystem extends JavaPlugin implements Listener { @Getter private static BauSystem instance; public static final String PREFIX = ColorConfig.HIGHLIGHT + "BauSystem" + ColorConfig.OTHER + "ยป " + ColorConfig.BASE; @Override public void onEnable() { // LOGGER fixLogging(); instance = this; SWUtils.setBausystem(instance); try { PrototypeLoader.load(); RegionLoader.load(); } catch (SecurityException e) { Bukkit.getLogger().log(Level.SEVERE, e.getMessage(), e); Bukkit.shutdown(); return; } new Updater(PrototypeLoader.file, PrototypeLoader::load); new Updater(RegionLoader.file, RegionLoader::load); LinkageUtils.link(); } @Override public void onDisable() { LinkageUtils.unlink(); RegionLoader.save(); } private void fixLogging() { System.setErr(new PrintStream(new OutputStream() { private StringBuilder current = new StringBuilder(); @Override public void write(int b) throws IOException { if (b == '\n') { String logging = current.toString(); if (logging.contains("SLF4J")) { Bukkit.getLogger().info(logging); } else { Bukkit.getLogger().warning(logging); } current = new StringBuilder(); } else { current.append((char) b); } } })); } }