diff --git a/core/build.gradle b/core/build.gradle index 86e6933c..e94fcd3a 100644 --- a/core/build.gradle +++ b/core/build.gradle @@ -3,6 +3,9 @@ description = "Core code shared by all versions" dependencies { implementation project(":smylib:core") + implementation 'org.apache.logging.log4j:log4j-api:2.8.1' + implementation 'com.google.code.gson:gson:2.11.0' + implementation 'javax.xml.bind:jaxb-api:2.3.1' testImplementation project(":smylib:testing") } \ No newline at end of file diff --git a/core/src/main/java/net/smyler/terramap/Terramap.java b/core/src/main/java/net/smyler/terramap/Terramap.java new file mode 100644 index 00000000..3028d6d1 --- /dev/null +++ b/core/src/main/java/net/smyler/terramap/Terramap.java @@ -0,0 +1,31 @@ +package net.smyler.terramap; + +import com.google.gson.Gson; +import net.smyler.terramap.http.HttpClient; +import org.apache.logging.log4j.Logger; + +public interface Terramap { + + static Terramap instance() { + return InstanceHolder.instance; + } + + String MOD_ID = "terramap"; + + Logger logger(); + + HttpClient http(); + + Gson gson(); + + Gson gsonPretty(); + + class InstanceHolder { + private static Terramap instance; + public static void setInstance(Terramap instance) { + instance.logger().info("Setting Terramap instance of class {}", instance.getClass().getName()); + InstanceHolder.instance = instance; + } + } + +} diff --git a/core/src/main/java/net/smyler/terramap/TerramapResources.java b/core/src/main/java/net/smyler/terramap/TerramapResources.java index 0743f911..d5dfdc99 100644 --- a/core/src/main/java/net/smyler/terramap/TerramapResources.java +++ b/core/src/main/java/net/smyler/terramap/TerramapResources.java @@ -4,8 +4,7 @@ public final class TerramapResources { - public static final String MOD_ID = "terramap"; - public static final Identifier TEXTURES = new Identifier(MOD_ID, "textures"); + public static final Identifier TEXTURES = new Identifier(Terramap.MOD_ID, "textures"); public static final Identifier GUI_TEXTURES = TEXTURES.resolve("gui"); public static final Identifier SPRITES = GUI_TEXTURES.resolve("sprites"); diff --git a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlDocument.java b/core/src/main/java/net/smyler/terramap/files/kml/KmlDocument.java similarity index 95% rename from forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlDocument.java rename to core/src/main/java/net/smyler/terramap/files/kml/KmlDocument.java index 2f483c7e..6278d744 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlDocument.java +++ b/core/src/main/java/net/smyler/terramap/files/kml/KmlDocument.java @@ -1,4 +1,4 @@ -package fr.thesmyler.terramap.files.kml; +package net.smyler.terramap.files.kml; import java.util.ArrayList; import java.util.List; diff --git a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlFile.java b/core/src/main/java/net/smyler/terramap/files/kml/KmlFile.java similarity index 67% rename from forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlFile.java rename to core/src/main/java/net/smyler/terramap/files/kml/KmlFile.java index f6c3602e..f8b347de 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlFile.java +++ b/core/src/main/java/net/smyler/terramap/files/kml/KmlFile.java @@ -1,9 +1,11 @@ -package fr.thesmyler.terramap.files.kml; +package net.smyler.terramap.files.kml; import java.io.File; import java.io.IOException; import java.io.OutputStream; import java.nio.file.Files; +import java.util.zip.ZipEntry; +import java.util.zip.ZipOutputStream; import javax.xml.bind.JAXBContext; import javax.xml.bind.JAXBException; @@ -13,10 +15,8 @@ import javax.xml.bind.annotation.XmlRootElement; import javax.xml.bind.annotation.XmlTransient; -import org.apache.commons.compress.archivers.zip.ZipArchiveEntry; -import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream; +import net.smyler.terramap.Terramap; -import fr.thesmyler.terramap.TerramapMod; @XmlRootElement(name="kml") public class KmlFile { @@ -39,19 +39,18 @@ public void save(File file, boolean compressed) throws IOException { marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE); try(OutputStream stream = Files.newOutputStream(file.toPath())) { if(compressed) { - try(ZipArchiveOutputStream compressedStream = new ZipArchiveOutputStream(stream)) { - ZipArchiveEntry entry = new ZipArchiveEntry("terramap.kml"); - compressedStream.putArchiveEntry(entry); + try(ZipOutputStream compressedStream = new ZipOutputStream(stream)) { + ZipEntry entry = new ZipEntry("terramap.kml"); + compressedStream.putNextEntry(entry); marshaller.marshal(this, compressedStream); - compressedStream.closeArchiveEntry(); } } else { marshaller.marshal(this, stream); } } } catch(JAXBException e) { - TerramapMod.logger.error("Something went seriously wrong when saving a kml file. Save aborted."); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Something went seriously wrong when saving a kml file. Save aborted."); + Terramap.instance().logger().catching(e); } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPlacemark.java b/core/src/main/java/net/smyler/terramap/files/kml/KmlPlacemark.java similarity index 95% rename from forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPlacemark.java rename to core/src/main/java/net/smyler/terramap/files/kml/KmlPlacemark.java index 639b5379..e4e2b731 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPlacemark.java +++ b/core/src/main/java/net/smyler/terramap/files/kml/KmlPlacemark.java @@ -1,4 +1,4 @@ -package fr.thesmyler.terramap.files.kml; +package net.smyler.terramap.files.kml; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlTransient; diff --git a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPoint.java b/core/src/main/java/net/smyler/terramap/files/kml/KmlPoint.java similarity index 95% rename from forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPoint.java rename to core/src/main/java/net/smyler/terramap/files/kml/KmlPoint.java index d26e8977..87c6f345 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/files/kml/KmlPoint.java +++ b/core/src/main/java/net/smyler/terramap/files/kml/KmlPoint.java @@ -1,4 +1,4 @@ -package fr.thesmyler.terramap.files.kml; +package net.smyler.terramap.files.kml; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlTransient; diff --git a/core/src/main/java/net/smyler/terramap/http/HttpClient.java b/core/src/main/java/net/smyler/terramap/http/HttpClient.java new file mode 100644 index 00000000..90c53453 --- /dev/null +++ b/core/src/main/java/net/smyler/terramap/http/HttpClient.java @@ -0,0 +1,23 @@ +package net.smyler.terramap.http; + +import net.smyler.terramap.Terramap; + +import java.util.concurrent.CompletableFuture; + +/** + * Asynchronous HTTP client abstraction. + * The implementation should focus on implementing + * efficient GET requests with compliant caching. + * Implementations should support cancellation of the CompletableFuture. + *
+ * Access the singleton from {@link Terramap#http()} + * + * @author Smyler + */ +public interface HttpClient { + + CompletableFuture get(String url); + + void setMaxConcurrentRequests(String host, int maxConcurrentRequests); + +} diff --git a/forge/src/main/java/fr/thesmyler/terramap/util/CopyrightHolder.java b/core/src/main/java/net/smyler/terramap/util/CopyrightHolder.java similarity index 92% rename from forge/src/main/java/fr/thesmyler/terramap/util/CopyrightHolder.java rename to core/src/main/java/net/smyler/terramap/util/CopyrightHolder.java index 0892346a..46225126 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/util/CopyrightHolder.java +++ b/core/src/main/java/net/smyler/terramap/util/CopyrightHolder.java @@ -1,4 +1,4 @@ -package fr.thesmyler.terramap.util; +package net.smyler.terramap.util; import net.smyler.smylib.text.Text; diff --git a/forge/src/main/java/fr/thesmyler/terramap/util/geo/GeoServices.java b/core/src/main/java/net/smyler/terramap/util/geo/GeoServices.java similarity index 90% rename from forge/src/main/java/fr/thesmyler/terramap/util/geo/GeoServices.java rename to core/src/main/java/net/smyler/terramap/util/geo/GeoServices.java index f9e2f2a8..6140e08d 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/util/geo/GeoServices.java +++ b/core/src/main/java/net/smyler/terramap/util/geo/GeoServices.java @@ -1,4 +1,4 @@ -package fr.thesmyler.terramap.util.geo; +package net.smyler.terramap.util.geo; import java.awt.Desktop; import java.io.File; @@ -14,12 +14,11 @@ import java.text.DecimalFormatSymbols; import java.util.Locale; -import fr.thesmyler.terramap.TerramapMod; -import fr.thesmyler.terramap.files.kml.KmlDocument; -import fr.thesmyler.terramap.files.kml.KmlFile; -import fr.thesmyler.terramap.files.kml.KmlPlacemark; -import fr.thesmyler.terramap.files.kml.KmlPoint; -import net.smyler.terramap.util.geo.GeoUtil; +import net.smyler.terramap.files.kml.KmlDocument; +import net.smyler.terramap.files.kml.KmlFile; +import net.smyler.terramap.files.kml.KmlPlacemark; +import net.smyler.terramap.files.kml.KmlPoint; +import net.smyler.terramap.Terramap; /** * Utility class to open various geo services such as osm, Google Maps, Earth, etc... @@ -65,8 +64,8 @@ public static String formatStringWithCoords(String str, int zoomLevel, double lo .replace("{longitude}", dispLong) .replace("{place}", dispPlace); } catch (UnsupportedEncodingException e) { - TerramapMod.logger.error("Failed to format a string with coordinates: "); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to format a string with coordinates: "); + Terramap.instance().logger().catching(e); } return str; } @@ -124,8 +123,8 @@ public static void openInGoogleEarthPro(double lon, double lat) { Desktop.getDesktop().open(file); file.deleteOnExit(); } catch(Exception e) { - TerramapMod.logger.error("There was an error when trying to open a place in Google Earth"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("There was an error when trying to open a place in Google Earth"); + Terramap.instance().logger().catching(e); } } @@ -134,10 +133,10 @@ public static void openURI(String uriStr) { URI uri = new URI(uriStr); Desktop.getDesktop().browse(uri); } catch (IOException | UnsupportedOperationException e) { - TerramapMod.logger.error("Failed to open uri: " + uriStr); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to open uri: {}", uriStr); + Terramap.instance().logger().catching(e); } catch (URISyntaxException e) { - TerramapMod.logger.error("Tried to open a malformed URI: " + uriStr); + Terramap.instance().logger().error("Tried to open a malformed URI: {}", uriStr); } } diff --git a/fabric/src/main/java/net/smyler/terramap/TerramapFabricMod.java b/fabric/src/main/java/net/smyler/terramap/TerramapFabricMod.java index d3a12b47..05e2e312 100644 --- a/fabric/src/main/java/net/smyler/terramap/TerramapFabricMod.java +++ b/fabric/src/main/java/net/smyler/terramap/TerramapFabricMod.java @@ -1,20 +1,54 @@ package net.smyler.terramap; +import com.google.gson.Gson; +import com.google.gson.GsonBuilder; import net.fabricmc.api.ModInitializer; import net.minecraft.client.Minecraft; import net.smyler.smylib.SmyLib; import net.smyler.smylib.game.WrappedMinecraft; +import net.smyler.smylib.json.TextJsonAdapter; +import net.smyler.smylib.text.Text; +import net.smyler.terramap.http.HttpClient; import org.apache.logging.log4j.Logger; import static org.apache.logging.log4j.LogManager.getLogger; -public class TerramapFabricMod implements ModInitializer { +public class TerramapFabricMod implements ModInitializer, Terramap { + + private final Logger logger = getLogger("terramap"); + private final Gson gson = new GsonBuilder() + .registerTypeAdapter(Text.class, new TextJsonAdapter()) + .create(); + private final Gson gsonPretty = new GsonBuilder() + .registerTypeAdapter(Text.class, new TextJsonAdapter()) + .setPrettyPrinting() + .create(); - public static final Logger LOGGER = getLogger("terramap"); @Override public void onInitialize() { - LOGGER.info("Initializing Terramap"); - SmyLib.initializeGameClient(new WrappedMinecraft(Minecraft.getInstance()), LOGGER); + Terramap.InstanceHolder.setInstance(this); + this.logger.info("Initializing Terramap"); + SmyLib.initializeGameClient(new WrappedMinecraft(Minecraft.getInstance()), this.logger); + } + + @Override + public Logger logger() { + return this.logger; + } + + @Override + public HttpClient http() { + return null; + } + + @Override + public Gson gson() { + return this.gson; + } + + @Override + public Gson gsonPretty() { + return this.gsonPretty; } } diff --git a/forge/src/main/java/fr/thesmyler/smylibgui/SmyLibGuiTextures.java b/forge/src/main/java/fr/thesmyler/smylibgui/SmyLibGuiTextures.java index a33075c3..f72623af 100644 --- a/forge/src/main/java/fr/thesmyler/smylibgui/SmyLibGuiTextures.java +++ b/forge/src/main/java/fr/thesmyler/smylibgui/SmyLibGuiTextures.java @@ -1,7 +1,7 @@ package fr.thesmyler.smylibgui; -import fr.thesmyler.terramap.TerramapMod; import net.minecraft.util.ResourceLocation; +import net.smyler.terramap.Terramap; public final class SmyLibGuiTextures { @@ -10,7 +10,7 @@ private SmyLibGuiTextures() {} public static final ResourceLocation WIDGET_TEXTURES; static { - WIDGET_TEXTURES = new ResourceLocation(TerramapMod.MODID, "textures/gui/widgets.png"); + WIDGET_TEXTURES = new ResourceLocation(Terramap.MOD_ID, "textures/gui/widgets.png"); } } diff --git a/forge/src/main/java/fr/thesmyler/smylibgui/util/Cursors.java b/forge/src/main/java/fr/thesmyler/smylibgui/util/Cursors.java index 2d901543..8c00effc 100644 --- a/forge/src/main/java/fr/thesmyler/smylibgui/util/Cursors.java +++ b/forge/src/main/java/fr/thesmyler/smylibgui/util/Cursors.java @@ -2,13 +2,13 @@ import java.nio.IntBuffer; +import net.smyler.terramap.Terramap; import org.lwjgl.BufferUtils; import org.lwjgl.LWJGLException; import org.lwjgl.input.Cursor; import org.lwjgl.input.Mouse; import org.lwjgl.opengl.GL11; -import fr.thesmyler.terramap.TerramapMod; import net.minecraft.client.Minecraft; import net.minecraft.client.renderer.texture.ITextureObject; import net.minecraft.util.ResourceLocation; @@ -19,11 +19,11 @@ //TODO Have a wrapper class for lwjgl cursors public final class Cursors { - public static final Cursor CURSOR_MOVE = loadCursorFromTexture(new ResourceLocation(TerramapMod.MODID, "textures/gui/cursors/move.png"), 32, 32); - public static final Cursor CURSOR_RESIZE_VERTICAL = loadCursorFromTexture(new ResourceLocation(TerramapMod.MODID, "textures/gui/cursors/resize_vertical.png"), 16, 32); - public static final Cursor CURSOR_RESIZE_HORIZONTAL = loadCursorFromTexture(new ResourceLocation(TerramapMod.MODID, "textures/gui/cursors/resize_horizontal.png"), 32, 16); - public static final Cursor CURSOR_RESIZE_DIAGONAL_1 = loadCursorFromTexture(new ResourceLocation(TerramapMod.MODID, "textures/gui/cursors/resize_diag1.png"), 32, 32); - public static final Cursor CURSOR_RESIZE_DIAGONAL_2 = loadCursorFromTexture(new ResourceLocation(TerramapMod.MODID, "textures/gui/cursors/resize_diag2.png"), 32, 32); + public static final Cursor CURSOR_MOVE = loadCursorFromTexture(new ResourceLocation(Terramap.MOD_ID, "textures/gui/cursors/move.png"), 32, 32); + public static final Cursor CURSOR_RESIZE_VERTICAL = loadCursorFromTexture(new ResourceLocation(Terramap.MOD_ID, "textures/gui/cursors/resize_vertical.png"), 16, 32); + public static final Cursor CURSOR_RESIZE_HORIZONTAL = loadCursorFromTexture(new ResourceLocation(Terramap.MOD_ID, "textures/gui/cursors/resize_horizontal.png"), 32, 16); + public static final Cursor CURSOR_RESIZE_DIAGONAL_1 = loadCursorFromTexture(new ResourceLocation(Terramap.MOD_ID, "textures/gui/cursors/resize_diag1.png"), 32, 32); + public static final Cursor CURSOR_RESIZE_DIAGONAL_2 = loadCursorFromTexture(new ResourceLocation(Terramap.MOD_ID, "textures/gui/cursors/resize_diag2.png"), 32, 32); static { if(Minecraft.IS_RUNNING_ON_MAC) { @@ -66,8 +66,8 @@ private static Cursor loadCursorFromTexture(ResourceLocation loc, int hotX, int try { return new Cursor(width, height, hotX, hotY, 1, buffer, BufferUtils.createIntBuffer(1)); } catch (LWJGLException e) { - TerramapMod.logger.error("Failed to load a cutom cursor for " + loc); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to load a custom cursor for {}", loc); + Terramap.instance().logger().catching(e); } } return Mouse.getNativeCursor(); diff --git a/forge/src/main/java/fr/thesmyler/terramap/TerramapClientContext.java b/forge/src/main/java/fr/thesmyler/terramap/TerramapClientContext.java index d5bdc498..f2edf566 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/TerramapClientContext.java +++ b/forge/src/main/java/fr/thesmyler/terramap/TerramapClientContext.java @@ -38,12 +38,12 @@ import net.buildtheearth.terraplusplus.projection.mercator.WebMercatorProjection; import net.minecraft.client.Minecraft; import net.minecraft.client.entity.EntityPlayerSP; -import net.minecraft.client.multiplayer.ServerData; import net.minecraft.client.multiplayer.WorldClient; import net.minecraft.entity.Entity; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.util.ResourceLocation; +import net.smyler.terramap.Terramap; import org.jetbrains.annotations.NotNull; import static net.smyler.smylib.SmyLib.getGameClient; @@ -89,12 +89,15 @@ public class TerramapClientContext { private final ClientSaveManager saveManager; public TerramapClientContext() { - this.saveManager = new ClientSaveManager(getGameClient().gameDirectory().resolve("terramap")); + this.saveManager = new ClientSaveManager( + getGameClient().gameDirectory().resolve("terramap"), + Terramap.instance().gsonPretty() + ); try { this.saveManager.createDirectoryIfNecessary(); } catch (IOException exception) { - TerramapMod.logger.error("An error occurred when preparing Terramap's save directory"); - TerramapMod.logger.catching(exception); + Terramap.instance().logger().error("An error occurred when preparing Terramap's save directory"); + Terramap.instance().logger().catching(exception); } this.reloadState(); } @@ -156,8 +159,8 @@ public TerrainPreview getTerrainPreview() { public void setGeneratorSettings(EarthGeneratorSettings genSettings) { if(genSettings != null && this.hasSledgehammer() && !TerramapUtil.isBteCompatible(genSettings)) { - TerramapMod.logger.error("Terramap server is reporting a projection which is not compatible with BTE, yet Sledgehammer is installer on the proxy!!"); - TerramapMod.logger.error("The proxy will be assuming a BTE projection, things will not work!"); + Terramap.instance().logger().error("Terramap server is reporting a projection which is not compatible with BTE, yet Sledgehammer is installer on the proxy!!"); + Terramap.instance().logger().error("The proxy will be assuming a BTE projection, things will not work!"); //TODO Warning on the GUI } this.getSavedState().generatorSettings = genSettings; @@ -238,7 +241,7 @@ public String getTpCommand() { } public void setTpCommand(String tpCmd) { - TerramapMod.logger.info("Setting tp command defined by server"); + Terramap.instance().logger().info("Setting tp command defined by server"); this.tpCommand = tpCmd; } @@ -250,38 +253,38 @@ public void reloadState() { MinecraftServerInfo serverInfo = getGameClient().currentServerInfo(); if(this.proxyForceGlobalSettings && this.proxyUUID != null) { this.state = this.saveManager.loadProxyState(this.proxyUUID); - TerramapMod.logger.debug("Loaded proxy saved state for UUID {} (forced by proxy)", this.proxyUUID); + Terramap.instance().logger().debug("Loaded proxy saved state for UUID {} (forced by proxy)", this.proxyUUID); } else if(this.worldUUID != null) { this.state = this.saveManager.loadWorldState(this.worldUUID); - TerramapMod.logger.debug("Loaded world saved state for UUID {}", this.worldUUID); + Terramap.instance().logger().debug("Loaded world saved state for UUID {}", this.worldUUID); } else if(this.proxyUUID != null) { this.state = this.saveManager.loadProxyState(this.proxyUUID); - TerramapMod.logger.debug("Loaded proxy saved state for UUID {} (world unknown)", this.proxyUUID); + Terramap.instance().logger().debug("Loaded proxy saved state for UUID {} (world unknown)", this.proxyUUID); } else if (serverInfo != null) { this.state = this.saveManager.loadServerState(serverInfo); - TerramapMod.logger.debug("Loaded server saved state for server {} ({})",serverInfo.name, serverInfo.host); + Terramap.instance().logger().debug("Loaded server saved state for server {} ({})",serverInfo.name, serverInfo.host); } else { this.state = this.saveManager.getDefaultState(); - TerramapMod.logger.debug("Went back to default state"); + Terramap.instance().logger().debug("Went back to default state"); } } public void saveState() { - ServerData servData = Minecraft.getMinecraft().getCurrentServerData(); + MinecraftServerInfo servData = getGameClient().currentServerInfo(); if(this.proxyForceGlobalSettings && this.proxyUUID != null) { this.saveManager.saveProxyState(this.proxyUUID, this.state); - TerramapMod.logger.debug("Saved proxy state for UUID {} (forced by proxy)", this.proxyUUID); + Terramap.instance().logger().debug("Saved proxy state for UUID {} (forced by proxy)", this.proxyUUID); } else if(this.worldUUID != null) { this.saveManager.saveWorldState(this.worldUUID, this.state); - TerramapMod.logger.debug("Saved world state for UUID {}", this.worldUUID); + Terramap.instance().logger().debug("Saved world state for UUID {}", this.worldUUID); } else if(this.proxyUUID != null) { this.saveManager.saveProxyState(this.proxyUUID, this.state); - TerramapMod.logger.debug("Saved proxy state for UUID {} (world unknown)", this.proxyUUID); + Terramap.instance().logger().debug("Saved proxy state for UUID {} (world unknown)", this.proxyUUID); } else if (servData != null) { this.saveManager.saveServerState(servData, this.state); - TerramapMod.logger.debug("Saved server state for server {} ({})",servData.serverName, servData.serverIP); + Terramap.instance().logger().debug("Saved server state for server {} ({})",servData.name, servData.host); } else { - TerramapMod.logger.debug("Did not save state for unreliable context"); + Terramap.instance().logger().debug("Did not save state for unreliable context"); } } @@ -495,7 +498,7 @@ public void tryShowWelcomeToast() { new TextureToast( getGameClient().translator().format("terramap.toasts.welcome.title"), getGameClient().translator().format("terramap.toasts.welcome.text", key), - new ResourceLocation(TerramapMod.MODID, "logo/50.png"))); + new ResourceLocation(Terramap.MOD_ID, "logo/50.png"))); this.setHasShownWelcomeMessage(true); } } @@ -521,7 +524,7 @@ public static TerramapClientContext getContext() { } public static void resetContext() { - TerramapMod.logger.info("Reseting client context"); + Terramap.instance().logger().info("Reseting client context"); TiledMapProvider.SERVER.setLastError(null); TiledMapProvider.PROXY.setLastError(null); TerramapClientContext.instance = new TerramapClientContext(); diff --git a/forge/src/main/java/fr/thesmyler/terramap/TerramapConfig.java b/forge/src/main/java/fr/thesmyler/terramap/TerramapConfig.java index c9f41022..5d83465b 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/TerramapConfig.java +++ b/forge/src/main/java/fr/thesmyler/terramap/TerramapConfig.java @@ -5,6 +5,7 @@ import net.minecraftforge.fml.client.event.ConfigChangedEvent; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.common.eventhandler.SubscribeEvent; +import net.smyler.terramap.Terramap; import static net.smyler.smylib.SmyLib.getGameClient; @@ -14,7 +15,7 @@ * Terramap's config * */ -@Config(modid=TerramapMod.MODID) +@Config(modid=Terramap.MOD_ID) public class TerramapConfig { public static final class Minimap { @@ -288,10 +289,10 @@ public static final class Server { public static boolean enableDebugMaps = false; public static void sync() { - ConfigManager.sync(TerramapMod.MODID, Config.Type.INSTANCE); + ConfigManager.sync(Terramap.MOD_ID, Config.Type.INSTANCE); } - @Mod.EventBusSubscriber(modid = TerramapMod.MODID) + @Mod.EventBusSubscriber(modid = Terramap.MOD_ID) private static class EventHandler { /** @@ -301,7 +302,7 @@ private static class EventHandler { */ @SubscribeEvent public static void onConfigChanged(final ConfigChangedEvent.OnConfigChangedEvent event) { - if (event.getModID().equals(TerramapMod.MODID)) { + if (event.getModID().equals(Terramap.MOD_ID)) { TerramapConfig.sync(); } TerramapMod.proxy.onConfigChanged(event); diff --git a/forge/src/main/java/fr/thesmyler/terramap/TerramapMod.java b/forge/src/main/java/fr/thesmyler/terramap/TerramapMod.java index 80ab932b..c65fec1e 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/TerramapMod.java +++ b/forge/src/main/java/fr/thesmyler/terramap/TerramapMod.java @@ -6,10 +6,12 @@ import com.google.gson.Gson; import com.google.gson.GsonBuilder; import fr.thesmyler.terramap.util.json.EarthGeneratorSettingsAdapter; -import net.buildtheearth.terraplusplus.generator.EarthGenerator; import net.buildtheearth.terraplusplus.generator.EarthGeneratorSettings; import net.smyler.smylib.json.TextJsonAdapter; import net.smyler.smylib.text.Text; +import net.smyler.terramap.Terramap; +import net.smyler.terramap.http.HttpClient; +import net.smyler.terramap.http.TerraplusplusHttpClient; import org.apache.logging.log4j.Logger; import fr.thesmyler.terramap.TerramapVersion.InvalidVersionString; @@ -29,27 +31,26 @@ import net.minecraftforge.fml.relauncher.Side; //TODO Credit TwelveMonkeys in the readme -@Mod(modid=TerramapMod.MODID, useMetadata=true, dependencies="required-after:terraplusplus@[1.0.569,)") -public class TerramapMod { +@Mod(modid=Terramap.MOD_ID, useMetadata=true, dependencies="required-after:terraplusplus@[1.0.569,)") +public class TerramapMod implements Terramap { - public static final String MODID = "terramap"; - public static final String AUTHOR_EMAIL = "smyler at mail dot com"; public static final String STYLE_UPDATE_HOSTNAME = "styles.terramap.thesmyler.fr"; private static TerramapVersion version; // Read from the metadata + private final HttpClient http = new TerraplusplusHttpClient(); + // These are notable versions public static final TerramapVersion OLDEST_COMPATIBLE_CLIENT = new TerramapVersion(1, 0, 0, ReleaseType.BETA, 6, 0); - public static final TerramapVersion OLDEST_COMPATIBLE_SERVER = new TerramapVersion(1, 0, 0, ReleaseType.BETA, 6, 0); public static final TerramapVersion OLDEST_TERRA121_TERRAMAP_VERSION = new TerramapVersion(1, 0, 0, ReleaseType.BETA, 6, 7); - public static Logger logger; + private Logger logger; - public static final Gson GSON = new GsonBuilder() + private final Gson gson = new GsonBuilder() .registerTypeAdapter(EarthGeneratorSettings.class, new EarthGeneratorSettingsAdapter()) .registerTypeAdapter(Text.class, new TextJsonAdapter()) .create(); - public static final Gson GSON_PRETTY = new GsonBuilder() + private final Gson gsonPretty = new GsonBuilder() .registerTypeAdapter(EarthGeneratorSettings.class, new EarthGeneratorSettingsAdapter()) .registerTypeAdapter(Text.class, new TextJsonAdapter()) .setPrettyPrinting() @@ -63,19 +64,20 @@ public class TerramapMod { @EventHandler public void preInit(FMLPreInitializationEvent event) { - logger = event.getModLog(); + this.logger = event.getModLog(); + Terramap.InstanceHolder.setInstance(this); String versionStr = event.getModMetadata().version; if (System.getProperties().containsKey("terramap.debug")) { - logger.info("Debug flag is set, forcing a development version string."); + this.logger.info("Debug flag is set, forcing a development version string."); versionStr= "${version}"; } try { TerramapMod.version = new TerramapVersion(versionStr); } catch(InvalidVersionString e) { - logger.error("Failed to parse Terramap version number from string " + versionStr + ", will be assuming a 1.0.0 release."); + this.logger.error("Failed to parse Terramap version number from string {}, will be assuming a 1.0.0 release.", versionStr); TerramapMod.version = new TerramapVersion(1, 0, 0); } - TerramapMod.logger.info("Terramap version: " + getVersion()); + this.logger.info("Terramap version: {}", getVersion()); TerramapMod.proxy.preInit(event); File mapStyleFile = new File(event.getModConfigurationDirectory().getAbsolutePath() + "/terramap_user_styles.json"); MapStylesLibrary.setConfigMapFile(mapStyleFile); @@ -108,4 +110,24 @@ public void onServerStarts(FMLServerStartingEvent event) { } + @Override + public Logger logger() { + return this.logger; + } + + @Override + public HttpClient http() { + return this.http; + } + + @Override + public Gson gson() { + return this.gson; + } + + @Override + public Gson gsonPretty() { + return this.gsonPretty; + } + } diff --git a/forge/src/main/java/fr/thesmyler/terramap/TerramapVersion.java b/forge/src/main/java/fr/thesmyler/terramap/TerramapVersion.java index f077733d..ce594719 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/TerramapVersion.java +++ b/forge/src/main/java/fr/thesmyler/terramap/TerramapVersion.java @@ -3,6 +3,7 @@ import java.util.Arrays; import java.util.Map; +import net.smyler.terramap.Terramap; import org.jetbrains.annotations.NotNull; import org.apache.logging.log4j.util.Strings; @@ -302,12 +303,12 @@ public TerraDependency getTerraDependency() { public static TerramapVersion getClientVersion(EntityPlayerMP player) { Map modList = NetworkDispatcher.get(player.connection.netManager).getModList(); TerramapVersion version = null; - String remoteVersion = modList.get(TerramapMod.MODID); + String remoteVersion = modList.get(Terramap.MOD_ID); if(remoteVersion != null) { try { version = new TerramapVersion(remoteVersion); } catch(InvalidVersionString e) { - TerramapMod.logger.warn("Failed to parse a client's Terramap version: " + remoteVersion + " : " + e.getLocalizedMessage()); + Terramap.instance().logger().warn("Failed to parse a client's Terramap version: {} : {}", remoteVersion, e.getLocalizedMessage()); } } return version; diff --git a/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ClientTerramapEventHandler.java b/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ClientTerramapEventHandler.java index 7d5d2b6b..64be5dfa 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ClientTerramapEventHandler.java +++ b/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ClientTerramapEventHandler.java @@ -2,12 +2,11 @@ import fr.thesmyler.smylibgui.event.HudScreenInitEvent; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.gui.HudScreenHandler; import fr.thesmyler.terramap.gui.screens.LayerRenderingOffsetPopup; import fr.thesmyler.terramap.gui.widgets.map.MapLayer; import fr.thesmyler.terramap.input.KeyBindings; -import fr.thesmyler.terramap.util.geo.GeoServices; +import net.smyler.terramap.util.geo.GeoServices; import net.buildtheearth.terraplusplus.projection.GeographicProjection; import net.buildtheearth.terraplusplus.projection.OutOfProjectionBoundsException; import net.buildtheearth.terraplusplus.util.CardinalDirection; @@ -25,6 +24,7 @@ import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.SideOnly; import net.smyler.smylib.gui.popups.Popup; +import net.smyler.terramap.Terramap; import java.util.Objects; @@ -81,7 +81,7 @@ public void onClientConnected(ClientConnectedToServerEvent event) { @SubscribeEvent public void onChangeDimension(PlayerChangedDimensionEvent event) { // Not called on client... - TerramapMod.logger.info(event.player.world.isRemote); + Terramap.instance().logger().info(event.player.world.isRemote); if(event.player.world.isRemote) { TerramapClientContext.getContext().resetWorld(); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ServerTerramapEventHandler.java b/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ServerTerramapEventHandler.java index ad4588ae..8f8f0af5 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ServerTerramapEventHandler.java +++ b/forge/src/main/java/fr/thesmyler/terramap/eventhandlers/ServerTerramapEventHandler.java @@ -10,6 +10,7 @@ import net.minecraftforge.fml.common.gameevent.PlayerEvent.PlayerLoggedInEvent; import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.SideOnly; +import net.smyler.terramap.Terramap; @SideOnly(Side.SERVER) public class ServerTerramapEventHandler { @@ -25,14 +26,14 @@ public void onPlayerLoggedIn(PlayerLoggedInEvent event){ if(TerramapConfig.SERVER.joinWithoutModMessage.length() > 0) player.sendMessage(ITextComponent.Serializer.fromJsonLenient(TerramapConfig.SERVER.joinWithoutModMessage)); } catch(Exception e) { - TerramapMod.logger.error("Failed to send custom join message to client, make sure your json text is valid"); + Terramap.instance().logger().error("Failed to send custom join message to client, make sure your json text is valid"); } } else if(remoteVersion.isOlder(TerramapMod.OLDEST_COMPATIBLE_CLIENT)){ try { if(TerramapConfig.SERVER.joinWithOutdatedModMessage.length() > 0) player.sendMessage(ITextComponent.Serializer.fromJsonLenient(TerramapConfig.SERVER.joinWithOutdatedModMessage)); } catch(Exception e) { - TerramapMod.logger.error("Failed to send custom join message to client, make sure your json text is valid"); + Terramap.instance().logger().error("Failed to send custom join message to client, make sure your json text is valid"); } } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/LayerRenderingOffsetPopup.java b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/LayerRenderingOffsetPopup.java index 0dba7f3c..c703b128 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/LayerRenderingOffsetPopup.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/LayerRenderingOffsetPopup.java @@ -27,7 +27,7 @@ import net.smyler.smylib.math.Vec2dMutable; import static fr.thesmyler.terramap.gui.widgets.map.MapLayerRegistry.OFFSET_PREVIEW; -import static fr.thesmyler.terramap.util.geo.GeoServices.formatZoomLevelForDisplay; +import static net.smyler.terramap.util.geo.GeoServices.formatZoomLevelForDisplay; import static net.smyler.smylib.SmyLib.getGameClient; import static net.smyler.smylib.text.ImmutableText.ofTranslation; diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/TerramapScreen.java b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/TerramapScreen.java index 034ec170..ace1778c 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/TerramapScreen.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/TerramapScreen.java @@ -9,13 +9,14 @@ import net.smyler.smylib.gui.sprites.WarningWidget; import net.smyler.smylib.text.ImmutableText; import net.smyler.smylib.text.TextStyle; +import net.smyler.terramap.Terramap; +import net.smyler.terramap.util.geo.GeoServices; import org.jetbrains.annotations.Nullable; import fr.thesmyler.terramap.gui.widgets.map.*; import fr.thesmyler.terramap.gui.widgets.map.layer.OnlineRasterMapLayer; import fr.thesmyler.terramap.maps.raster.CachingRasterTiledMap; import fr.thesmyler.terramap.maps.raster.imp.UrlTiledMap; -import fr.thesmyler.terramap.util.geo.*; import net.buildtheearth.terraplusplus.generator.EarthGeneratorSettings; import net.smyler.smylib.Color; import net.smyler.smylib.game.GameClient; @@ -65,7 +66,7 @@ import net.minecraft.util.ITabCompleter; import static fr.thesmyler.terramap.gui.widgets.map.MapLayerRegistry.LayerRegistration; -import static fr.thesmyler.terramap.util.geo.GeoServices.formatZoomLevelForDisplay; +import static net.smyler.terramap.util.geo.GeoServices.formatZoomLevelForDisplay; import static net.smyler.smylib.Color.WHITE; import static net.smyler.smylib.Color.YELLOW; import static net.smyler.smylib.SmyLib.getGameClient; @@ -539,7 +540,7 @@ public boolean shouldPauseGame() { } private boolean search(String text) { - TerramapMod.logger.info("Geo search: " + text); + Terramap.instance().logger().info("Geo search: {}", text); //TODO Search return true; // Let the search box loose focus } diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/config/TerramapConfigScreen.java b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/config/TerramapConfigScreen.java index d91d0982..7c8a30f9 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/screens/config/TerramapConfigScreen.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/screens/config/TerramapConfigScreen.java @@ -7,6 +7,7 @@ import net.smyler.smylib.game.GameClient; import net.smyler.smylib.game.Key; import net.smyler.smylib.game.Translator; +import net.smyler.terramap.Terramap; import org.jetbrains.annotations.Nullable; import net.smyler.smylib.gui.containers.FlexibleWidgetContainer; @@ -23,7 +24,6 @@ import net.smyler.smylib.gui.widgets.text.TextFieldWidget; import net.smyler.smylib.gui.widgets.text.TextWidget; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.TerramapConfig; import fr.thesmyler.terramap.maps.raster.MapStylesLibrary; @@ -179,8 +179,8 @@ public void init() { try { Desktop.getDesktop().open(MapStylesLibrary.getFile()); } catch (IOException e) { - TerramapMod.logger.error("Failed to open map style config file: "); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to open map style config file: "); + Terramap.instance().logger().catching(e); } })); diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/RibbonCompassWidget.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/RibbonCompassWidget.java index f3a2235f..5700bd8a 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/RibbonCompassWidget.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/RibbonCompassWidget.java @@ -2,6 +2,7 @@ import net.smyler.smylib.gui.DrawContext; import net.smyler.smylib.gui.GlState; +import net.smyler.terramap.Terramap; import org.lwjgl.opengl.GL11; import net.smyler.smylib.gui.containers.WidgetContainer; @@ -9,7 +10,6 @@ import fr.thesmyler.smylibgui.util.TextureUtil.TextureProperties; import fr.thesmyler.smylibgui.util.TextureUtil.UnknownTextureException; import net.smyler.smylib.gui.widgets.Widget; -import fr.thesmyler.terramap.TerramapMod; import net.minecraft.client.Minecraft; import net.minecraft.client.renderer.BufferBuilder; import net.minecraft.client.renderer.GlStateManager; @@ -21,8 +21,8 @@ public class RibbonCompassWidget implements Widget { - private static final ResourceLocation COMPASS_BACKGROUND_TEXTURE = new ResourceLocation(TerramapMod.MODID, "textures/gui/compass_ribbon_background.png"); - private static final ResourceLocation COMPASS_INDICATOR_TEXTURE = new ResourceLocation(TerramapMod.MODID, "textures/gui/compass_ribbon_indicator.png"); + private static final ResourceLocation COMPASS_BACKGROUND_TEXTURE = new ResourceLocation(Terramap.MOD_ID, "textures/gui/compass_ribbon_background.png"); + private static final ResourceLocation COMPASS_INDICATOR_TEXTURE = new ResourceLocation(Terramap.MOD_ID, "textures/gui/compass_ribbon_indicator.png"); private float x, y; private final int z; @@ -43,8 +43,8 @@ public RibbonCompassWidget(float x, float y, int z, float width) { this.indicatorHeight = p2.getHeight(); this.indicatorWidth = p2.getWidth(); } catch (UnknownTextureException e) { - TerramapMod.logger.error("Failed to get texture heiht for ribbon compass"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to get texture heiht for ribbon compass"); + Terramap.instance().logger().catching(e); this.height = 16; } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapMenuWidget.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapMenuWidget.java index 1cd8569c..39fe1aff 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapMenuWidget.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapMenuWidget.java @@ -9,7 +9,7 @@ import net.smyler.smylib.gui.Font; import net.smyler.terramap.util.geo.GeoPoint; import net.smyler.terramap.util.geo.GeoPointReadOnly; -import fr.thesmyler.terramap.util.geo.GeoServices; +import net.smyler.terramap.util.geo.GeoServices; import net.buildtheearth.terraplusplus.control.PresetEarthGui; import net.buildtheearth.terraplusplus.generator.EarthGeneratorSettings; import net.buildtheearth.terraplusplus.projection.GeographicProjection; diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapWidget.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapWidget.java index 4a19ae56..08827eb7 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapWidget.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/MapWidget.java @@ -19,7 +19,6 @@ import net.smyler.smylib.gui.widgets.text.TextAlignment; import net.smyler.smylib.gui.widgets.text.TextWidget; import fr.thesmyler.terramap.MapContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.gui.widgets.markers.MarkerControllerManager; import fr.thesmyler.terramap.gui.widgets.markers.controllers.FeatureVisibilityController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.MainPlayerMarkerController; @@ -30,10 +29,11 @@ import fr.thesmyler.terramap.gui.widgets.markers.controllers.RightClickMarkerController; import fr.thesmyler.terramap.gui.widgets.markers.markers.Marker; import fr.thesmyler.terramap.gui.widgets.markers.markers.entities.MainPlayerMarker; -import fr.thesmyler.terramap.util.CopyrightHolder; +import net.smyler.terramap.util.CopyrightHolder; import net.minecraft.profiler.Profiler; import net.smyler.smylib.text.ImmutableText; import net.smyler.smylib.text.Text; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.GeoPoint; import net.smyler.terramap.util.geo.GeoPointMutable; import net.smyler.terramap.util.geo.GeoPointReadOnly; @@ -383,7 +383,7 @@ private void updateMarkers(float mouseX, float mouseY) { if(id != null && id.equals(this.restoreTrackingId)) { this.controller.track(markerToAdd); this.restoreTrackingId = null; - TerramapMod.logger.debug("Restored tracking with " + id); + Terramap.instance().logger().debug("Restored tracking with {}", id); } } } @@ -745,8 +745,8 @@ public void restore(SavedMapState state) { try { layer = this.createLayer(layerState.type); } catch (IllegalArgumentException e) { - TerramapMod.logger.warn("Could not restore a map layer. Did someone mess with the save file?"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().warn("Could not restore a map layer. Did someone mess with the save file?"); + Terramap.instance().logger().catching(e); continue; } this.setLayerZ(layer, layerState.z); @@ -758,8 +758,8 @@ public void restore(SavedMapState state) { try { layer.loadSettings(layerState.settings); } catch (Exception e) { - TerramapMod.logger.error("Caught exception when loading layer settings. Did someone mess with the save file?"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Caught exception when loading layer settings. Did someone mess with the save file?"); + Terramap.instance().logger().catching(e); } } Map controllers = this.getVisibilityControllers(); diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/McChunksLayer.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/McChunksLayer.java index 0d11f6f2..8decd780 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/McChunksLayer.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/McChunksLayer.java @@ -15,11 +15,11 @@ import net.smyler.smylib.gui.widgets.buttons.ToggleButtonWidget; import net.smyler.smylib.gui.widgets.text.TextWidget; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.gui.widgets.map.MapLayer; import fr.thesmyler.terramap.gui.widgets.map.MapWidget; import net.smyler.smylib.gui.DrawContext; import net.smyler.smylib.gui.Font; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.GeoPointImmutable; import net.smyler.terramap.util.geo.GeoPointMutable; import net.smyler.terramap.util.geo.GeoPointReadOnly; @@ -120,7 +120,7 @@ public void loadSettings(JsonObject json) { this.setRenderBlocks(json.get("renderBlocks").getAsBoolean()); this.loadColor(json.getAsJsonObject("colorBlocks"), this::setColorBlocks); } catch (NullPointerException | ClassCastException | IllegalStateException e) { - TerramapMod.logger.warn("Failed to load mc boundaries layer settings: {}", json); + Terramap.instance().logger().warn("Failed to load mc boundaries layer settings: {}", json); } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/OnlineRasterMapLayer.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/OnlineRasterMapLayer.java index fb1102ab..56b4daf9 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/OnlineRasterMapLayer.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/OnlineRasterMapLayer.java @@ -13,7 +13,7 @@ import fr.thesmyler.terramap.gui.widgets.map.MapWidget; import fr.thesmyler.terramap.maps.raster.RasterTiledMap; import fr.thesmyler.terramap.maps.raster.imp.ColorTiledMap; -import fr.thesmyler.terramap.util.CopyrightHolder; +import net.smyler.terramap.util.CopyrightHolder; import net.smyler.smylib.game.GameClient; import net.smyler.smylib.gui.DrawContext; import net.smyler.smylib.gui.Font; diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/RasterMapLayer.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/RasterMapLayer.java index 17529db2..460ae88d 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/RasterMapLayer.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/map/layer/RasterMapLayer.java @@ -10,11 +10,11 @@ import fr.thesmyler.terramap.gui.widgets.map.MapWidget; import fr.thesmyler.terramap.maps.raster.RasterTile; import fr.thesmyler.terramap.maps.raster.RasterTiledMap; -import fr.thesmyler.terramap.util.geo.*; import net.smyler.smylib.Color; import net.smyler.smylib.gui.DrawContext; import net.smyler.smylib.gui.Font; import net.smyler.terramap.util.geo.GeoPointReadOnly; +import net.smyler.terramap.util.geo.GeoServices; import net.smyler.terramap.util.geo.TilePos; import net.smyler.terramap.util.geo.TilePos.InvalidTilePositionException; import net.smyler.smylib.math.Mat2d; diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/MarkerControllerManager.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/MarkerControllerManager.java index 3216d426..a14709f3 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/MarkerControllerManager.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/MarkerControllerManager.java @@ -6,13 +6,13 @@ import java.util.Map; import fr.thesmyler.terramap.MapContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.gui.widgets.markers.controllers.AnimalMarkerController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.MainPlayerMarkerController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.MarkerController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.MobMarkerController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.OtherPlayerMarkerController; import fr.thesmyler.terramap.gui.widgets.markers.controllers.RightClickMarkerController; +import net.smyler.terramap.Terramap; public abstract class MarkerControllerManager { @@ -31,9 +31,9 @@ public static void registerController(Class> contr controller.newInstance(); CONTROLLER_CLASSES.get(context).add(controller); } catch(Exception e) { - TerramapMod.logger.error("Failed to create a test marker controller instance for " + controller.getCanonicalName()); - TerramapMod.logger.error("This marker controller class will not be registered. See stack trace for details."); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to create a test marker controller instance for {}", controller.getCanonicalName()); + Terramap.instance().logger().error("This marker controller class will not be registered. See stack trace for details."); + Terramap.instance().logger().catching(e); } } @@ -44,9 +44,9 @@ public static MarkerController[] createControllers(MapContext context) { try { controllers[i++] = clazz.newInstance(); } catch (InstantiationException | IllegalAccessException e) { - TerramapMod.logger.error("Failed to create a marker controller, things will be unstable!"); - TerramapMod.logger.error("Failed to instantiate " + clazz.getCanonicalName()); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to create a marker controller, things will be unstable!"); + Terramap.instance().logger().error("Failed to instantiate {}", clazz.getCanonicalName()); + Terramap.instance().logger().catching(e); } } return controllers; diff --git a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/markers/entities/AbstractLivingMarker.java b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/markers/entities/AbstractLivingMarker.java index 5824c6ba..f75f84be 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/markers/entities/AbstractLivingMarker.java +++ b/forge/src/main/java/fr/thesmyler/terramap/gui/widgets/markers/markers/entities/AbstractLivingMarker.java @@ -6,11 +6,11 @@ import fr.thesmyler.smylibgui.util.RenderUtil; import fr.thesmyler.terramap.MapContext; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.gui.widgets.map.MapWidget; import fr.thesmyler.terramap.gui.widgets.markers.controllers.MarkerController; import fr.thesmyler.terramap.gui.widgets.markers.markers.AbstractMovingMarker; import net.smyler.smylib.gui.DrawContext; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.GeoPointImmutable; import net.buildtheearth.terraplusplus.projection.GeographicProjection; import net.buildtheearth.terraplusplus.projection.OutOfProjectionBoundsException; @@ -24,7 +24,7 @@ public abstract class AbstractLivingMarker extends AbstractMovingMarker { - protected static final ResourceLocation ENTITY_MARKERS_TEXTURE = new ResourceLocation(TerramapMod.MODID, "textures/gui/entity_markers.png"); + protected static final ResourceLocation ENTITY_MARKERS_TEXTURE = new ResourceLocation(Terramap.MOD_ID, "textures/gui/entity_markers.png"); protected ResourceLocation texture; protected int u, v, textureWidth, textureHeight; diff --git a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/CachingRasterTiledMap.java b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/CachingRasterTiledMap.java index 9c2d7a48..5488cecb 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/CachingRasterTiledMap.java +++ b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/CachingRasterTiledMap.java @@ -4,8 +4,8 @@ import java.util.LinkedList; import java.util.Map; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.TerramapConfig; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.TilePos; import net.smyler.terramap.util.geo.TilePosImmutable; import net.smyler.terramap.util.geo.WebMercatorBounds; @@ -108,8 +108,8 @@ private void prepareLowTiles() { try { this.getTile(zoom, x, y).getTexture(); } catch (Throwable e) { - TerramapMod.logger.error("Failed to load a low level texture for map: %s-%sv%s at %s/%s/%s", this.getId(), this.getProvider(), this.getProviderVersion(),zoom, x, y); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to load a low level texture for map: %s-%sv%s at %s/%s/%s", this.getId(), this.getProvider(), this.getProviderVersion(),zoom, x, y); + Terramap.instance().logger().catching(e); } } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/MapStylesLibrary.java b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/MapStylesLibrary.java index 299157f4..e1857e23 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/MapStylesLibrary.java +++ b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/MapStylesLibrary.java @@ -1,17 +1,12 @@ package fr.thesmyler.terramap.maps.raster; -import java.io.BufferedReader; -import java.io.File; -import java.io.IOException; -import java.io.InputStream; -import java.io.InputStreamReader; +import java.io.*; import java.net.InetAddress; import java.net.UnknownHostException; import java.nio.charset.Charset; import java.nio.file.Files; import java.util.HashMap; import java.util.Map; -import java.util.concurrent.CompletableFuture; import javax.naming.NamingException; import javax.naming.directory.Attributes; @@ -21,13 +16,9 @@ import fr.thesmyler.terramap.TerramapConfig; import fr.thesmyler.terramap.maps.raster.imp.UrlTiledMap; import net.smyler.smylib.text.Text; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.WebMercatorBounds; -import io.netty.buffer.ByteBuf; -import io.netty.buffer.ByteBufInputStream; -import net.buildtheearth.terraplusplus.util.http.Http; -import static fr.thesmyler.terramap.TerramapMod.GSON; -import static fr.thesmyler.terramap.TerramapMod.GSON_PRETTY; public class MapStylesLibrary { @@ -76,9 +67,9 @@ public static void loadBuiltIns() { baseMaps.putAll(loadFromJson(json.toString(), TiledMapProvider.BUILT_IN)); } } catch(Exception e) { - TerramapMod.logger.fatal("Failed to read built-in map styles, Terramap is likely to not work properly!"); - TerramapMod.logger.fatal("Path: " + path); - TerramapMod.logger.catching(e); + Terramap.instance().logger().fatal("Failed to read built-in map styles, Terramap is likely to not work properly!"); + Terramap.instance().logger().fatal("Path: {}", path); + Terramap.instance().logger().catching(e); TiledMapProvider.BUILT_IN.setLastError(e); } @@ -89,8 +80,8 @@ public static void loadInternals() { try { // We currently have no internal styles } catch(Exception e) { - TerramapMod.logger.error("Failed to load internal map styles"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to load internal map styles"); + Terramap.instance().logger().catching(e); TiledMapProvider.INTERNAL.setLastError(e); } } @@ -101,7 +92,7 @@ public static void loadInternals() { * parses it as redirect as would most browsers * and does a request to the corresponding url. * The body of that request is then parsed as a map style json config file. - * + *
* This should be called after {@link #loadBuiltIns()} so it overwrites it. * * @param hostname - the hostname to lookup @@ -112,18 +103,18 @@ public static void loadFromOnline(String hostname) { try { url = resolveUpdateURL(hostname); } catch (UnknownHostException | NamingException e1) { - TerramapMod.logger.error("Failed to resolve map styles urls!"); - TerramapMod.logger.catching(e1); + Terramap.instance().logger().error("Failed to resolve map styles urls!"); + Terramap.instance().logger().catching(e1); return; } - CompletableFuture request = Http.get(url); - request.whenComplete((b, e) -> { + + Terramap.instance().http().get(url).whenComplete((b, e) -> { if(e != null) { - TerramapMod.logger.error("Failed to download updated map style file!"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to download updated map style file!"); + Terramap.instance().logger().catching(e); TiledMapProvider.ONLINE.setLastError(e); } - try(BufferedReader txtReader = new BufferedReader(new InputStreamReader(new ByteBufInputStream(b)))) { + try(BufferedReader txtReader = new BufferedReader(new InputStreamReader(new ByteArrayInputStream(b)))) { StringBuilder json = new StringBuilder(); String line = txtReader.readLine(); while(line != null) { @@ -132,8 +123,8 @@ public static void loadFromOnline(String hostname) { } baseMaps.putAll(loadFromJson(json.toString(), TiledMapProvider.ONLINE)); } catch(Exception f) { - TerramapMod.logger.error("Failed to parse updated map style file!"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to parse updated map style file!"); + Terramap.instance().logger().catching(e); TiledMapProvider.ONLINE.setLastError(e); } }); @@ -146,18 +137,18 @@ public static void loadFromOnline(String hostname) { public static void loadFromConfigFile() { TiledMapProvider.CUSTOM.setLastError(null); if(configMapsFile == null) { - TerramapMod.logger.error("Map config file was null!"); + Terramap.instance().logger().error("Map config file was null!"); TiledMapProvider.CUSTOM.setLastError(new NullPointerException("Map style config files was null")); return; } if(!configMapsFile.exists()) { try { - TerramapMod.logger.debug("Map config file did not exist, creating a blank one."); + Terramap.instance().logger().debug("Map config file did not exist, creating a blank one."); MapStyleFile mapFile = new MapStyleFile(new MapFileMetadata(0, "Add custom map styles here. See an example at styles.terramap.thesmyler.fr (open in your browser, do not add http or https prefix)")); - Files.write(configMapsFile.toPath(), GSON_PRETTY.toJson(mapFile).getBytes(Charset.defaultCharset())); + Files.write(configMapsFile.toPath(), Terramap.instance().gsonPretty().toJson(mapFile).getBytes(Charset.defaultCharset())); } catch (IOException e) { - TerramapMod.logger.error("Failed to create map style config file!"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to create map style config file!"); + Terramap.instance().logger().catching(e); TiledMapProvider.CUSTOM.setLastError(e); } @@ -165,8 +156,8 @@ public static void loadFromConfigFile() { try { userMaps.putAll(loadFromFile(configMapsFile, TiledMapProvider.CUSTOM)); } catch (Exception e) { - TerramapMod.logger.error("Failed to read map style config file!"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to read map style config file!"); + Terramap.instance().logger().catching(e); TiledMapProvider.CUSTOM.setLastError(e); } } @@ -231,12 +222,12 @@ private static Map loadFromFile(File file, TiledMapProvider } private static Map loadFromJson(String json, TiledMapProvider provider) { - MapStyleFile savedStyles = GSON.fromJson(json, MapStyleFile.class); + MapStyleFile savedStyles = Terramap.instance().gson().fromJson(json, MapStyleFile.class); Map styles = new HashMap<>(); for(String id: savedStyles.maps.keySet()) { UrlTiledMap style = readFromSaved(id, savedStyles.maps.get(id), provider, savedStyles.metadata.version, savedStyles.metadata.comment); if(!TerramapConfig.enableDebugMaps && style.isDebug()) { - TerramapMod.logger.info("Not loading debug map style " + style.getId()); + Terramap.instance().logger().info("Not loading debug map style {}", style.getId()); continue; } styles.put(id, style); @@ -281,6 +272,7 @@ private static class SavedMapStyle { } + @SuppressWarnings("MismatchedQueryAndUpdateOfCollection") private static class MapStyleFile { Map maps; diff --git a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/ColorTiledMap.java b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/ColorTiledMap.java index f255c88b..3e222272 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/ColorTiledMap.java +++ b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/ColorTiledMap.java @@ -1,9 +1,9 @@ package fr.thesmyler.terramap.maps.raster.imp; import net.smyler.smylib.Color; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.maps.raster.CachingRasterTiledMap; import fr.thesmyler.terramap.maps.raster.TiledMapProvider; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.ImageUtil; import net.smyler.terramap.util.geo.TilePosImmutable; import net.minecraft.client.Minecraft; @@ -26,7 +26,7 @@ public ColorTiledMap(Color color, String name) { TextureManager textureManager = Minecraft.getMinecraft().getTextureManager(); DynamicTexture texture = new DynamicTexture(ImageUtil.imageFromColor(256, 256, this.color.asRGBInt())); this.textureLocation = textureManager.getDynamicTextureLocation( - TerramapMod.MODID + ":color_tile_" + this.color.asHexString(), texture); + Terramap.MOD_ID + ":color_tile_" + this.color.asHexString(), texture); } else { this.textureLocation = null; } diff --git a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlRasterTile.java b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlRasterTile.java index e469f3bb..8b922f5e 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlRasterTile.java +++ b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlRasterTile.java @@ -1,19 +1,16 @@ package fr.thesmyler.terramap.maps.raster.imp; import java.awt.image.BufferedImage; +import java.io.ByteArrayInputStream; import java.io.IOException; -import java.net.URL; import java.util.concurrent.CompletableFuture; import java.util.concurrent.ExecutionException; import javax.imageio.ImageIO; import fr.thesmyler.terramap.maps.raster.RasterTile; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.geo.TilePosImmutable; -import io.netty.buffer.ByteBuf; -import io.netty.buffer.ByteBufInputStream; -import net.buildtheearth.terraplusplus.util.http.Disk; -import net.buildtheearth.terraplusplus.util.http.Http; import net.minecraft.client.Minecraft; import net.minecraft.client.renderer.texture.DynamicTexture; import net.minecraft.client.renderer.texture.TextureManager; @@ -28,7 +25,7 @@ public class UrlRasterTile implements RasterTile { private final TilePosImmutable pos; private final String url; private ResourceLocation texture = null; - private CompletableFuture textureTask; + private CompletableFuture textureTask; public UrlRasterTile(String urlPattern, TilePosImmutable pos) { @@ -62,7 +59,7 @@ public boolean isTextureAvailable() { public ResourceLocation getTexture() throws Throwable { if(this.texture == null) { if(this.textureTask == null) { - this.textureTask = Http.get(this.getURL()); + this.textureTask = Terramap.instance().http().get(this.getURL()); } else this.tryLoadingTexture(); } return this.texture; @@ -85,11 +82,11 @@ private void tryLoadingTexture() throws Throwable { } Minecraft mc = Minecraft.getMinecraft(); TextureManager textureManager = mc.getTextureManager(); - ByteBuf buf = this.textureTask.get(); + byte[] buf = this.textureTask.get(); if(buf == null) throw new IOException("404 response"); - try (ByteBufInputStream is = new ByteBufInputStream(buf)) { + try (ByteArrayInputStream is = new ByteArrayInputStream(buf)) { BufferedImage image = ImageIO.read(is); - if(image == null) throw new IOException("Failed to read image! url: " + this.getURL() + " file: " + Disk.cacheFileFor(new URL(this.getURL()).getFile()).toString()); + if(image == null) throw new IOException("Failed to read image! url: " + this.getURL()); this.texture = textureManager.getDynamicTextureLocation("textures/gui/maps/" + this.getURL(), new DynamicTexture(image)); } } diff --git a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlTiledMap.java b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlTiledMap.java index c3f0f7f2..8d44a545 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlTiledMap.java +++ b/forge/src/main/java/fr/thesmyler/terramap/maps/raster/imp/UrlTiledMap.java @@ -6,14 +6,14 @@ import com.google.common.base.Strings; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.TerramapConfig; import fr.thesmyler.terramap.maps.raster.CachingRasterTiledMap; import fr.thesmyler.terramap.maps.raster.MapStylesLibrary; import fr.thesmyler.terramap.maps.raster.TiledMapProvider; import fr.thesmyler.terramap.network.SP2CMapStylePacket; -import fr.thesmyler.terramap.util.CopyrightHolder; +import net.smyler.terramap.util.CopyrightHolder; import net.smyler.smylib.text.Text; +import net.smyler.terramap.Terramap; import net.smyler.terramap.util.ImageUtil; import net.smyler.terramap.util.geo.TilePosImmutable; import net.smyler.terramap.util.geo.WebMercatorBounds; @@ -116,8 +116,8 @@ public void setup() { Http.setMaximumConcurrentRequestsTo(url, this.getMaxConcurrentRequests()); } } catch(IllegalArgumentException | MalformedURLException e) { - TerramapMod.logger.error("Failed to set max concurrent requests for host. Url :" + url); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to set max concurrent requests for host. Url :{}", url); + Terramap.instance().logger().catching(e); } } super.setup(); @@ -277,7 +277,7 @@ public void registerErrorTexture() { TextureManager textureManager = Minecraft.getMinecraft().getTextureManager(); int[] color = {170, 211, 223}; DynamicTexture texture = new DynamicTexture(ImageUtil.imageFromColor(256, 256, color)); - this.errorTileTexture = textureManager.getDynamicTextureLocation(TerramapMod.MODID + ":error_tile_texture", texture); + this.errorTileTexture = textureManager.getDynamicTextureLocation(Terramap.MOD_ID + ":error_tile_texture", texture); } } \ No newline at end of file diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/P2CSledgehammerHelloPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/P2CSledgehammerHelloPacket.java index 385a01bb..53f974b7 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/network/P2CSledgehammerHelloPacket.java +++ b/forge/src/main/java/fr/thesmyler/terramap/network/P2CSledgehammerHelloPacket.java @@ -10,6 +10,7 @@ import net.minecraftforge.fml.common.network.simpleimpl.IMessage; import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; +import net.smyler.terramap.Terramap; public class P2CSledgehammerHelloPacket implements IMessage { @@ -55,7 +56,7 @@ public P2CSledgehammerHelloPacketHandler(){} @Override public IMessage onMessage(P2CSledgehammerHelloPacket pkt, MessageContext ctx) { Minecraft.getMinecraft().addScheduledTask(() -> { - TerramapMod.logger.info("Got Sledgehammer hello, remote version is " + pkt.sledgehammerVersion); + Terramap.instance().logger().info("Got Sledgehammer hello, remote version is {}", pkt.sledgehammerVersion); TerramapClientContext.getContext().setSledgehammerVersion(pkt.sledgehammerVersion); TerramapClientContext.getContext().setPlayersSynchronizedByProxy(pkt.syncPlayers); TerramapClientContext.getContext().setSpectatorsSynchronizedByProxy(pkt.syncSpectators); diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/RemoteSynchronizer.java b/forge/src/main/java/fr/thesmyler/terramap/network/RemoteSynchronizer.java index 750a4624..7fd6187f 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/network/RemoteSynchronizer.java +++ b/forge/src/main/java/fr/thesmyler/terramap/network/RemoteSynchronizer.java @@ -24,6 +24,7 @@ import net.minecraft.world.World; import net.minecraft.world.WorldServer; import net.minecraftforge.fml.common.network.simpleimpl.IMessage; +import net.smyler.terramap.Terramap; public abstract class RemoteSynchronizer { @@ -45,7 +46,7 @@ public static void syncPlayers(WorldServer world) { } for(RegisteredForUpdatePlayer player: RemoteSynchronizer.playersToUpdate.values()) { if(ctime - player.lastRegisterTime > TerramapConfig.SERVER.syncHeartbeatTimeout - 10000 && !player.noticeSent) { - TerramapMod.logger.debug("Sending registration expires notice to " + player.player.getName()); + Terramap.instance().logger().debug("Sending registration expires notice to {}", player.player.getName()); TerramapNetworkManager.CHANNEL_MAPSYNC.sendTo(new SP2CRegistrationExpiresPacket(), player.player); player.noticeSent = true; } @@ -54,7 +55,7 @@ public static void syncPlayers(WorldServer world) { while (iterator.hasNext()) { RegisteredForUpdatePlayer player = iterator.next(); if(ctime - player.lastRegisterTime > TerramapConfig.SERVER.syncHeartbeatTimeout) { - TerramapMod.logger.debug("Unregistering " + player.player.getName() + " from map update as it did not renew its registration"); + Terramap.instance().logger().debug("Unregistering {} from map update as it did not renew its registration", player.player.getName()); iterator.remove(); TerramapNetworkManager.CHANNEL_MAPSYNC.sendTo(new SP2CRegistrationExpiresPacket(), player.player); } @@ -63,13 +64,13 @@ public static void syncPlayers(WorldServer world) { public static void registerPlayerForUpdates(EntityPlayerMP player) { if(PermissionManager.hasPermission(player, Permission.RADAR_PLAYERS)) { - TerramapMod.logger.debug("Registering player for map updates: " + player.getDisplayNameString()); + Terramap.instance().logger().debug("Registering player for map updates: {}", player.getDisplayNameString()); RemoteSynchronizer.playersToUpdate.put(player.getPersistentID(), new RegisteredForUpdatePlayer(player, System.currentTimeMillis())); } } public static void unregisterPlayerForUpdates(EntityPlayerMP player) { - TerramapMod.logger.debug("Unregistering player for map updates: " + player.getDisplayNameString()); + Terramap.instance().logger().debug("Unregistering player for map updates: {}", player.getDisplayNameString()); RemoteSynchronizer.playersToUpdate.remove(player.getPersistentID()); } @@ -123,12 +124,12 @@ public static void sendMapStylesToClient(EntityPlayerMP player) { } public static void onServerHello(S2CTerramapHelloPacket pkt) { - TerramapMod.logger.info("Got server hello, remote version is " + pkt.serverVersion); + Terramap.instance().logger().info("Got server hello, remote version is " + pkt.serverVersion); String jsonWorldSettings = null; if(pkt.worldSettings != null) { jsonWorldSettings = pkt.worldSettings.toString(); } - TerramapMod.logger.debug( + Terramap.instance().logger().debug( "Server version: " + pkt.serverVersion + "\t" + "Server worldSettings: " + jsonWorldSettings + "\t" + "Server UUID: " + pkt.worldUUID + "\t" + @@ -156,7 +157,7 @@ public static void onServerHello(S2CTerramapHelloPacket pkt) { ctx.setAllowsDecoRadar(pkt.enableDecoRadar); ctx.setServerWarpSupport(pkt.hasWarpSupport); } catch (InvalidVersionString e) { - TerramapMod.logger.warn("Failed to parse server version! will act as if the server did not have Terramap installed"); + Terramap.instance().logger().warn("Failed to parse server version! will act as if the server did not have Terramap installed"); } ctx.tryShowWelcomeToast(); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/SP2CMapStylePacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/SP2CMapStylePacket.java index 17e93537..766c79c3 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/network/SP2CMapStylePacket.java +++ b/forge/src/main/java/fr/thesmyler/terramap/network/SP2CMapStylePacket.java @@ -5,10 +5,10 @@ import com.google.gson.JsonParseException; import net.smyler.smylib.text.Text; +import net.smyler.terramap.Terramap; import org.apache.logging.log4j.util.Strings; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.TerramapConfig; import fr.thesmyler.terramap.maps.raster.TiledMapProvider; import fr.thesmyler.terramap.maps.raster.imp.UrlTiledMap; @@ -19,7 +19,6 @@ import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; -import static fr.thesmyler.terramap.TerramapMod.GSON; public class SP2CMapStylePacket implements IMessage { @@ -80,10 +79,10 @@ public void fromBytes(ByteBuf buf) { String key = NetworkUtil.decodeStringFromByteBuf(buf); String copyrightJson = NetworkUtil.decodeStringFromByteBuf(buf); try { - Text copyright = GSON.fromJson(copyrightJson, Text.class); + Text copyright = Terramap.instance().gson().fromJson(copyrightJson, Text.class); copyrights.put(key, copyright); } catch (JsonParseException e) { - TerramapMod.logger.warn("Received invalid map style copyright from server."); + Terramap.instance().logger().warn("Received invalid map style copyright from server."); } } this.copyrights = copyrights; @@ -129,7 +128,7 @@ public void toBytes(ByteBuf buf) { buf.writeInt(this.copyrights.size()); for(String key: this.copyrights.keySet()) { NetworkUtil.encodeStringToByteBuf(key, buf); - NetworkUtil.encodeStringToByteBuf(GSON.toJson(this.copyrights.get(key)), buf); + NetworkUtil.encodeStringToByteBuf(Terramap.instance().gson().toJson(this.copyrights.get(key)), buf); } buf.writeInt(this.minZoom); buf.writeInt(this.maxZoom); @@ -185,16 +184,16 @@ public SP2CMapStylePacketTerramapHandler() {} public IMessage onMessage(SP2CMapStylePacket message, MessageContext ctx) { try { UrlTiledMap map = message.getTiledMap(TiledMapProvider.SERVER); - TerramapMod.logger.debug("Got custom map style from server: " + map.getId() + " / " + String.join(";", map.getUrlPatterns())); + Terramap.instance().logger().debug("Got custom map style from server: {} / {}", map.getId(), String.join(";", map.getUrlPatterns())); if(!TerramapConfig.enableDebugMaps && map.isDebug()) { - TerramapMod.logger.debug("Ignoring debug map from server: " + map.getId()); + Terramap.instance().logger().debug("Ignoring debug map from server: {}", map.getId()); return null; } Minecraft.getMinecraft().addScheduledTask(() -> TerramapClientContext.getContext().addServerMapStyle(map)); } catch(Exception e) { - TerramapMod.logger.error("Failed to unpack a map style sent by the server"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to unpack a map style sent by the server"); + Terramap.instance().logger().catching(e); TiledMapProvider.SERVER.setLastError(e); } return null; @@ -210,15 +209,15 @@ public SP2CMapStylePacketSledgehammerHandler() {} public IMessage onMessage(SP2CMapStylePacket message, MessageContext ctx) { try { UrlTiledMap map = message.getTiledMap(TiledMapProvider.PROXY); - TerramapMod.logger.debug("Got custom map style from proxy: " + map.getId() + " / " + String.join(";", map.getUrlPatterns())); + Terramap.instance().logger().debug("Got custom map style from proxy: {} / {}", map.getId(), String.join(";", map.getUrlPatterns())); if(!TerramapConfig.enableDebugMaps && map.isDebug()) { - TerramapMod.logger.debug("Ignoring debug map from proxy: " + map.getId()); + Terramap.instance().logger().debug("Ignoring debug map from proxy: {}", map.getId()); return null; } Minecraft.getMinecraft().addScheduledTask(() -> TerramapClientContext.getContext().addProxyMapStyle(map)); } catch(Exception e) { - TerramapMod.logger.error("Failed to unpack a map style sent by the proxy"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to unpack a map style sent by the proxy"); + Terramap.instance().logger().catching(e); TiledMapProvider.PROXY.setLastError(e); } return null; diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/TerramapNetworkManager.java b/forge/src/main/java/fr/thesmyler/terramap/network/TerramapNetworkManager.java index ab79743f..56b86282 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/network/TerramapNetworkManager.java +++ b/forge/src/main/java/fr/thesmyler/terramap/network/TerramapNetworkManager.java @@ -1,6 +1,5 @@ package fr.thesmyler.terramap.network; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.network.P2CSledgehammerHelloPacket.P2CSledgehammerHelloPacketHandler; import fr.thesmyler.terramap.network.S2CTerramapHelloPacket.S2CTerramapHelloPacketHandler; import fr.thesmyler.terramap.network.S2CTpCommandPacket.S2CTpCommandPacketHandler; @@ -12,42 +11,19 @@ import fr.thesmyler.terramap.network.playersync.SP2CPlayerSyncPacket.S2CPlayerSyncPacketHandler; import fr.thesmyler.terramap.network.playersync.SP2CRegistrationExpiresPacket; import fr.thesmyler.terramap.network.playersync.SP2CRegistrationExpiresPacket.S2CRegistrationExpiresPacketHandler; -import fr.thesmyler.terramap.network.warps.C2SPCreateWarpPacket; -import fr.thesmyler.terramap.network.warps.C2SPCreateWarpPacket.C2SPCreateWarpPacketHandler; -import fr.thesmyler.terramap.network.warps.C2SPEditWarpPacket; -import fr.thesmyler.terramap.network.warps.C2SPEditWarpPacket.C2SPEditWarpPacketHandler; -import fr.thesmyler.terramap.network.warps.C2SPRequestMultiWarpPacket; -import fr.thesmyler.terramap.network.warps.C2SPRequestMultiWarpPacket.C2SPRequestMultiWarpPacketHandler; -import fr.thesmyler.terramap.network.warps.C2SPRequestWarpPacket; -import fr.thesmyler.terramap.network.warps.C2SPRequestWarpPacket.C2SPRequestWarpPacketHandler; -import fr.thesmyler.terramap.network.warps.SP2CCreateWarpConfirmationPacket; -import fr.thesmyler.terramap.network.warps.SP2CCreateWarpConfirmationPacket.SP2CCreateWarpConfirmationPacketProxyHandler; -import fr.thesmyler.terramap.network.warps.SP2CCreateWarpConfirmationPacket.SP2CCreateWarpConfirmationPacketServerHandler; -import fr.thesmyler.terramap.network.warps.SP2CEditWarpConfirmationPacket; -import fr.thesmyler.terramap.network.warps.SP2CEditWarpConfirmationPacket.SP2CEditWarpConfirmationPacketProxyHandler; -import fr.thesmyler.terramap.network.warps.SP2CEditWarpConfirmationPacket.SP2CEditWarpConfirmationPacketServerHandler; -import fr.thesmyler.terramap.network.warps.SP2CMultiWarpPacket; -import fr.thesmyler.terramap.network.warps.SP2CMultiWarpPacket.SP2CMultiWarpPacketProxyHandler; -import fr.thesmyler.terramap.network.warps.SP2CMultiWarpPacket.SP2CMultiWarpPacketServerHandler; -import fr.thesmyler.terramap.network.warps.SP2CWarpCommandPacket; -import fr.thesmyler.terramap.network.warps.SP2CWarpCommandPacket.SP2CWarpCommandPacketProxyHandler; -import fr.thesmyler.terramap.network.warps.SP2CWarpCommandPacket.SP2CWarpCommandPacketServerHandler; -import fr.thesmyler.terramap.network.warps.SP2CWarpPacket; -import fr.thesmyler.terramap.network.warps.SP2CWarpPacket.SP2CWarpPacketProxyHandler; -import fr.thesmyler.terramap.network.warps.SP2CWarpPacket.SP2CWarpPacketServerHandler; import net.minecraftforge.fml.common.network.NetworkRegistry; import net.minecraftforge.fml.common.network.simpleimpl.IMessage; import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; import net.minecraftforge.fml.common.network.simpleimpl.SimpleNetworkWrapper; import net.minecraftforge.fml.relauncher.Side; +import net.smyler.terramap.Terramap; -//TODO Test the warp protocol public abstract class TerramapNetworkManager { // The channel instances - public static final SimpleNetworkWrapper CHANNEL_TERRAMAP = NetworkRegistry.INSTANCE.newSimpleChannel(TerramapMod.MODID + ":terramap"); - public static final SimpleNetworkWrapper CHANNEL_MAPSYNC = NetworkRegistry.INSTANCE.newSimpleChannel(TerramapMod.MODID + ":mapsync"); - public static final SimpleNetworkWrapper CHANNEL_SLEDGEHAMMER = NetworkRegistry.INSTANCE.newSimpleChannel(TerramapMod.MODID + ":sh"); // Forge does not support channel names longer than 20 + public static final SimpleNetworkWrapper CHANNEL_TERRAMAP = NetworkRegistry.INSTANCE.newSimpleChannel(Terramap.MOD_ID + ":terramap"); + public static final SimpleNetworkWrapper CHANNEL_MAPSYNC = NetworkRegistry.INSTANCE.newSimpleChannel(Terramap.MOD_ID + ":mapsync"); + public static final SimpleNetworkWrapper CHANNEL_SLEDGEHAMMER = NetworkRegistry.INSTANCE.newSimpleChannel(Terramap.MOD_ID + ":sh"); // Forge does not support channel names longer than 20 /** * Registers the handlers @@ -58,15 +34,6 @@ public static void registerHandlers(Side side){ registerTerramapS2C(S2C_TERRAMAP_HELLO_DISCRIMINATOR, S2CTerramapHelloPacketHandler.class, S2CTerramapHelloPacket.class); registerTerramapS2C(S2C_TERRAMAP_TPCMD_DISCRIMINATOR, S2CTpCommandPacketHandler.class, S2CTpCommandPacket.class); registerTerramapS2C(S2C_TERRAMAP_MAPSTYLE_DISCRIMINATOR, SP2CMapStylePacketTerramapHandler.class, SP2CMapStylePacket.class); - registerTerramapC2S(C2S_TERRAMAP_REQUEST_WARP_DISCRIMINATOR, C2SPRequestWarpPacketHandler.class, C2SPRequestWarpPacket.class); - registerTerramapS2C(S2C_TERRAMAP_WARP_DISCRIMINATOR, SP2CWarpPacketServerHandler.class, SP2CWarpPacket.class); - registerTerramapC2S(C2S_TERRAMAP_REQUEST_MULTI_WARP_DISCRIMINATOR, C2SPRequestMultiWarpPacketHandler.class, C2SPRequestMultiWarpPacket.class); - registerTerramapS2C(S2C_TERRAMAP_MULTI_WARP_DISCRIMINATOR, SP2CMultiWarpPacketServerHandler.class, SP2CMultiWarpPacket.class); - registerTerramapC2S(C2S_TERRAMAP_CREATE_WARP_DISCRIMINATOR, C2SPCreateWarpPacketHandler.class, C2SPCreateWarpPacket.class); - registerTerramapS2C(S2C_TERRAMAP_CREATE_WARP_CONFIRMATION_DISCRIMINATOR, SP2CCreateWarpConfirmationPacketServerHandler.class, SP2CCreateWarpConfirmationPacket.class); - registerTerramapC2S(C2S_TERRAMAP_EDIT_WARP_DISCRIMINATOR, C2SPEditWarpPacketHandler.class, C2SPEditWarpPacket.class); - registerTerramapS2C(S2C_TERRAMAP_EDIT_WARP_CONFIRMATION_DISCRIMINATOR, SP2CEditWarpConfirmationPacketServerHandler.class, SP2CEditWarpConfirmationPacket.class); - registerTerramapS2C(S2C_TERRAMAP_WARP_COMMAND_DISCRIMINATOR, SP2CWarpCommandPacketServerHandler.class, SP2CWarpCommandPacket.class); registerMapsyncCP2S(C2SP_MAPSYNC_REGISTER_DISCRIMINATOR, C2SRegisterForUpdatesPacketHandler.class, C2SPRegisterForUpdatesPacket.class); registerMapsyncSP2C(SP2C_MAPSYNC_PLAYERSYNC_DISCRIMINATOR, S2CPlayerSyncPacketHandler.class, SP2CPlayerSyncPacket.class); @@ -74,15 +41,6 @@ public static void registerHandlers(Side side){ registerSledgehammerP2C(P2C_SH_HELLO_DISCRIMINATOR, P2CSledgehammerHelloPacketHandler.class, P2CSledgehammerHelloPacket.class); registerSledgehammerP2C(P2C_SH_MAPSTYLE_DISCRIMINATOR, SP2CMapStylePacketSledgehammerHandler.class, SP2CMapStylePacket.class); - registerSledgehammerC2P(C2P_SH_REQUEST_WARP_DISCRIMINATOR, C2SPRequestWarpPacketHandler.class, C2SPRequestWarpPacket.class); - registerSledgehammerP2C(P2C_SH_WARP_DISCRIMINATOR, SP2CWarpPacketProxyHandler.class, SP2CWarpPacket.class); - registerSledgehammerC2P(C2P_SH_REQUEST_MULTI_WARP_DISCRIMINATOR, C2SPRequestMultiWarpPacketHandler.class, C2SPRequestMultiWarpPacket.class); - registerSledgehammerP2C(P2C_SH_MULTI_WARP_DISCRIMINATOR, SP2CMultiWarpPacketProxyHandler.class, SP2CMultiWarpPacket.class); - registerSledgehammerC2P(C2P_SH_CREATE_WARP_DISCRIMINATOR, C2SPCreateWarpPacketHandler.class, C2SPCreateWarpPacket.class); - registerSledgehammerP2C(P2C_SH_CREATE_WARP_CONFIRMATION_DISCRIMINATOR, SP2CCreateWarpConfirmationPacketProxyHandler.class, SP2CCreateWarpConfirmationPacket.class); - registerSledgehammerC2P(C2P_SH_EDIT_WARP_DISCRIMINATOR, C2SPEditWarpPacketHandler.class, C2SPEditWarpPacket.class); - registerSledgehammerP2C(P2C_SH_EDIT_WARP_CONFIRMATION_DISCRIMINATOR, SP2CEditWarpConfirmationPacketProxyHandler.class, SP2CEditWarpConfirmationPacket.class); - registerSledgehammerP2C(P2C_SH_WARP_COMMAND_DISCRIMINATOR, SP2CWarpCommandPacketProxyHandler.class, SP2CWarpCommandPacket.class); } @@ -90,15 +48,6 @@ public static void registerHandlers(Side side){ private static final int S2C_TERRAMAP_HELLO_DISCRIMINATOR = 0; private static final int S2C_TERRAMAP_TPCMD_DISCRIMINATOR = 1; private static final int S2C_TERRAMAP_MAPSTYLE_DISCRIMINATOR = 2; - private static final int C2S_TERRAMAP_REQUEST_WARP_DISCRIMINATOR = 3; - private static final int S2C_TERRAMAP_WARP_DISCRIMINATOR = 4; - private static final int C2S_TERRAMAP_REQUEST_MULTI_WARP_DISCRIMINATOR = 5; - private static final int S2C_TERRAMAP_MULTI_WARP_DISCRIMINATOR = 6; - private static final int C2S_TERRAMAP_CREATE_WARP_DISCRIMINATOR = 7; - private static final int S2C_TERRAMAP_CREATE_WARP_CONFIRMATION_DISCRIMINATOR = 8; - private static final int C2S_TERRAMAP_EDIT_WARP_DISCRIMINATOR = 9; - private static final int S2C_TERRAMAP_EDIT_WARP_CONFIRMATION_DISCRIMINATOR = 10; - private static final int S2C_TERRAMAP_WARP_COMMAND_DISCRIMINATOR = 11; // terramap:mapsync private static final int C2SP_MAPSYNC_REGISTER_DISCRIMINATOR = 0; @@ -108,15 +57,6 @@ public static void registerHandlers(Side side){ //terramap:sh private static final int P2C_SH_HELLO_DISCRIMINATOR = 0; private static final int P2C_SH_MAPSTYLE_DISCRIMINATOR = 2; - private static final int C2P_SH_REQUEST_WARP_DISCRIMINATOR = 3; - private static final int P2C_SH_WARP_DISCRIMINATOR = 4; - private static final int C2P_SH_REQUEST_MULTI_WARP_DISCRIMINATOR = 5; - private static final int P2C_SH_MULTI_WARP_DISCRIMINATOR = 6; - private static final int C2P_SH_CREATE_WARP_DISCRIMINATOR = 7; - private static final int P2C_SH_CREATE_WARP_CONFIRMATION_DISCRIMINATOR = 8; - private static final int C2P_SH_EDIT_WARP_DISCRIMINATOR = 9; - private static final int P2C_SH_EDIT_WARP_CONFIRMATION_DISCRIMINATOR = 10; - private static final int P2C_SH_WARP_COMMAND_DISCRIMINATOR = 11; private static void registerTerramapS2C(int discriminator, Class> handlerclass, Class msgclass) { CHANNEL_TERRAMAP.registerMessage(handlerclass, msgclass, discriminator, Side.CLIENT); diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/playersync/SP2CRegistrationExpiresPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/playersync/SP2CRegistrationExpiresPacket.java index c32ccd12..34338946 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/network/playersync/SP2CRegistrationExpiresPacket.java +++ b/forge/src/main/java/fr/thesmyler/terramap/network/playersync/SP2CRegistrationExpiresPacket.java @@ -1,11 +1,11 @@ package fr.thesmyler.terramap.network.playersync; import fr.thesmyler.terramap.TerramapClientContext; -import fr.thesmyler.terramap.TerramapMod; import io.netty.buffer.ByteBuf; import net.minecraftforge.fml.common.network.simpleimpl.IMessage; import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; +import net.smyler.terramap.Terramap; public class SP2CRegistrationExpiresPacket implements IMessage { @@ -24,7 +24,7 @@ public static class S2CRegistrationExpiresPacketHandler implements IMessageHandl @Override public C2SPRegisterForUpdatesPacket onMessage(SP2CRegistrationExpiresPacket message, MessageContext ctx) { if(TerramapClientContext.getContext().needsUpdate()) { - TerramapMod.logger.debug("Renewing registration for map update to server"); + Terramap.instance().logger().debug("Renewing registration for map update to server"); return new C2SPRegisterForUpdatesPacket(true); } return null; diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/AbstractWarpFilter.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/AbstractWarpFilter.java deleted file mode 100644 index b2008837..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/AbstractWarpFilter.java +++ /dev/null @@ -1,21 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import io.netty.buffer.ByteBuf; - -/** - * Used to filter warps in multi warp requests - * - * TODO Implement warp filtering - * - * @author SmylerMC - * - */ -public abstract class AbstractWarpFilter { - - public abstract void writeToByteBuf(ByteBuf buf); - - public static AbstractWarpFilter readFromByteBuf(ByteBuf buf) { - return null; - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPCreateWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPCreateWarpPacket.java deleted file mode 100644 index 565d925b..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPCreateWarpPacket.java +++ /dev/null @@ -1,41 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.warp.Warp; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class C2SPCreateWarpPacket implements IMessage { - - private long requestId; - private Warp warp; - - public C2SPCreateWarpPacket(long requestId, Warp warp) { - this.requestId = requestId; - this.warp = warp; - } - public C2SPCreateWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.warp = Warp.readWarpFromByteBuf(buf); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - this.warp.encodeToByteBuf(buf); - } - - public static class C2SPCreateWarpPacketHandler implements IMessageHandler { - - @Override - public SP2CCreateWarpConfirmationPacket onMessage(C2SPCreateWarpPacket pkt, MessageContext ctx) { - return new SP2CCreateWarpConfirmationPacket(pkt.requestId, WarpRequestStatus.NOT_IMPLEMENTED); - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPEditWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPEditWarpPacket.java deleted file mode 100644 index bee8c10e..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPEditWarpPacket.java +++ /dev/null @@ -1,41 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.warp.Warp; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class C2SPEditWarpPacket implements IMessage { - - private long requestId; - private Warp warp; - - public C2SPEditWarpPacket(long requestId, Warp warp) { - this.requestId = requestId; - this.warp = warp; - } - public C2SPEditWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.warp = Warp.readWarpFromByteBuf(buf); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - this.warp.encodeToByteBuf(buf); - } - - public static class C2SPEditWarpPacketHandler implements IMessageHandler { - - @Override - public SP2CEditWarpConfirmationPacket onMessage(C2SPEditWarpPacket pkt, MessageContext ctx) { - return new SP2CEditWarpConfirmationPacket(pkt.requestId, WarpRequestStatus.NOT_IMPLEMENTED); - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestMultiWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestMultiWarpPacket.java deleted file mode 100644 index 9ffc783a..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestMultiWarpPacket.java +++ /dev/null @@ -1,56 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.network.NetworkUtil; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class C2SPRequestMultiWarpPacket implements IMessage { - - private long requestId; - private AbstractWarpFilter[] filters; - private String[] keys; - - public C2SPRequestMultiWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.filters = new AbstractWarpFilter[buf.readInt()]; - for(int i=0; i { - - @Override - public SP2CMultiWarpPacket onMessage(C2SPRequestMultiWarpPacket pkt, MessageContext ctx) { - return new SP2CMultiWarpPacket(pkt.requestId, WarpRequestStatus.NOT_IMPLEMENTED); - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestWarpPacket.java deleted file mode 100644 index 20cba3cf..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/C2SPRequestWarpPacket.java +++ /dev/null @@ -1,42 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.network.NetworkUtil; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class C2SPRequestWarpPacket implements IMessage { - - private long requestId; - private String warpId; - - public C2SPRequestWarpPacket(long id, String warpId) { - this.requestId = id; - this.warpId = warpId; - } - - public C2SPRequestWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.warpId = NetworkUtil.decodeStringFromByteBuf(buf); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - NetworkUtil.encodeStringToByteBuf(this.warpId, buf); - } - - public static class C2SPRequestWarpPacketHandler implements IMessageHandler { - - @Override - public SP2CWarpPacket onMessage(C2SPRequestWarpPacket pkt, MessageContext ctx) { - return new SP2CWarpPacket(pkt.requestId, WarpRequestStatus.NOT_IMPLEMENTED, null); - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CCreateWarpConfirmationPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CCreateWarpConfirmationPacket.java deleted file mode 100644 index 44d6937e..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CCreateWarpConfirmationPacket.java +++ /dev/null @@ -1,52 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class SP2CCreateWarpConfirmationPacket implements IMessage { - - private long requestId; - private WarpRequestStatus status; - - public SP2CCreateWarpConfirmationPacket(long requestId, WarpRequestStatus status) { - this.requestId = requestId; - this.status = status; - } - - public SP2CCreateWarpConfirmationPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.status = WarpRequestStatus.getFromNetworkCode(buf.readByte()); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - buf.writeByte(this.status.getNetworkCode()); - } - - public static class SP2CCreateWarpConfirmationPacketServerHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CCreateWarpConfirmationPacket message, MessageContext ctx) { - //TODO SP2CCreateWarpConfirmationPacketHandler - return null; - } - - } - - public static class SP2CCreateWarpConfirmationPacketProxyHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CCreateWarpConfirmationPacket message, MessageContext ctx) { - //TODO SP2CCreateWarpConfirmationPacketProxyHandler - return null; - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CEditWarpConfirmationPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CEditWarpConfirmationPacket.java deleted file mode 100644 index 5e7d91b7..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CEditWarpConfirmationPacket.java +++ /dev/null @@ -1,52 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class SP2CEditWarpConfirmationPacket implements IMessage { - - private long requestId; - private WarpRequestStatus status; - - public SP2CEditWarpConfirmationPacket(long requestId, WarpRequestStatus status) { - this.requestId = requestId; - this.status = status; - } - - public SP2CEditWarpConfirmationPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.status = WarpRequestStatus.getFromNetworkCode(buf.readByte()); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - buf.writeByte(this.status.getNetworkCode()); - } - - public static class SP2CEditWarpConfirmationPacketServerHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CEditWarpConfirmationPacket message, MessageContext ctx) { - //TODO SP2CEditWarpConfirmationPacketServerHandler - return null; - } - - } - - public static class SP2CEditWarpConfirmationPacketProxyHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CEditWarpConfirmationPacket message, MessageContext ctx) { - //TODO SP2CEditWarpConfirmationPacketProxyHandler - return null; - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CMultiWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CMultiWarpPacket.java deleted file mode 100644 index 6461940d..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CMultiWarpPacket.java +++ /dev/null @@ -1,67 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.warp.Warp; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class SP2CMultiWarpPacket implements IMessage { - - private long requestId; - private WarpRequestStatus status; - private Warp[] warps; - - public SP2CMultiWarpPacket(long requestId, WarpRequestStatus status, Warp... warps) { - this.requestId = requestId; - this.status = status; - this.warps = warps; - } - - public SP2CMultiWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.status = WarpRequestStatus.getFromNetworkCode(buf.readByte()); - if(status.isSuccess()) { - this.warps = new Warp[buf.readInt()]; - for(int i=0; i < this.warps.length; i++) { - this.warps[i] = Warp.readWarpFromByteBuf(buf); - } - } else { - this.warps = new Warp[0]; - } - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - buf.writeByte(this.status.getNetworkCode()); - buf.writeInt(this.warps.length); - for(Warp warp: this.warps) { - warp.encodeToByteBuf(buf); - } - } - - public static class SP2CMultiWarpPacketServerHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CMultiWarpPacket message, MessageContext ctx) { - //TODO SP2CMultiWarpPacketServerHandler - return null; - } - - } - - public static class SP2CMultiWarpPacketProxyHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CMultiWarpPacket message, MessageContext ctx) { - //TODO SP2CMultiWarpPacketProxyHandler - return null; - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpCommandPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpCommandPacket.java deleted file mode 100644 index c2fddd04..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpCommandPacket.java +++ /dev/null @@ -1,51 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import fr.thesmyler.terramap.network.NetworkUtil; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class SP2CWarpCommandPacket implements IMessage { - - public String cmd = ""; - - public SP2CWarpCommandPacket(String cmd) { - this.cmd = cmd; - } - - public SP2CWarpCommandPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.cmd = NetworkUtil.decodeStringFromByteBuf(buf); - } - - @Override - public void toBytes(ByteBuf buf) { - NetworkUtil.encodeStringToByteBuf(this.cmd, buf); - } - - public static class SP2CWarpCommandPacketServerHandler implements IMessageHandler { - - public SP2CWarpCommandPacketServerHandler() {} - - @Override - public IMessage onMessage(SP2CWarpCommandPacket message, MessageContext ctx) { - return null; - } - - } - - public static class SP2CWarpCommandPacketProxyHandler implements IMessageHandler { - - public SP2CWarpCommandPacketProxyHandler() {} - - @Override - public IMessage onMessage(SP2CWarpCommandPacket message, MessageContext ctx) { - return null; - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpPacket.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpPacket.java deleted file mode 100644 index f13dbab4..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/SP2CWarpPacket.java +++ /dev/null @@ -1,60 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -import org.jetbrains.annotations.Nullable; - -import fr.thesmyler.terramap.warp.Warp; -import io.netty.buffer.ByteBuf; -import net.minecraftforge.fml.common.network.simpleimpl.IMessage; -import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler; -import net.minecraftforge.fml.common.network.simpleimpl.MessageContext; - -public class SP2CWarpPacket implements IMessage { - - private long requestId; - private WarpRequestStatus status; - private Warp warp; - - public SP2CWarpPacket(long requestId, WarpRequestStatus status, @Nullable Warp warp) { - this.requestId = requestId; - this.status = status; - this.warp = warp; - } - - public SP2CWarpPacket() {} - - @Override - public void fromBytes(ByteBuf buf) { - this.requestId = buf.readLong(); - this.status = WarpRequestStatus.getFromNetworkCode(buf.readByte()); - } - - @Override - public void toBytes(ByteBuf buf) { - buf.writeLong(this.requestId); - buf.writeByte(this.status.getNetworkCode()); - if(this.warp != null) { - this.warp.encodeToByteBuf(buf); - } - } - - public static class SP2CWarpPacketServerHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CWarpPacket message, MessageContext ctx) { - //TODO SP2CWarpPacketServerHandler - return null; - } - - } - - public static class SP2CWarpPacketProxyHandler implements IMessageHandler { - - @Override - public IMessage onMessage(SP2CWarpPacket message, MessageContext ctx) { - //TODO SP2CWarpPacketProxyHandler - return null; - } - - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/network/warps/WarpRequestStatus.java b/forge/src/main/java/fr/thesmyler/terramap/network/warps/WarpRequestStatus.java deleted file mode 100644 index 27c90baa..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/network/warps/WarpRequestStatus.java +++ /dev/null @@ -1,42 +0,0 @@ -package fr.thesmyler.terramap.network.warps; - -public enum WarpRequestStatus { - - OK(0x00, true), // Everything went fine, the request has been handled - MULTIPART(0x01, true), // To many matching warps, other packets will follow - TOO_MANY(0x02, false), // To many matching warps, this request will not be handled - NO_SUCH_WARP(0x03, false), // The warp did not exist - NOT_IMPLEMENTED(0x04, false), // Warps are not supported - INVALID_FILTER(0x05, false), // The request contained an invalid filter - INVALID_KEYS(0x06, false), // One of the keys requested cannot be included in multi request - FORBIDDEN(0x07, false), // The user did not have the required permission to make that request - UNKNOWN(Byte.MAX_VALUE, false); // The status code was not known - - private final byte code; - private final boolean success; - - WarpRequestStatus(int networkCode, boolean success) { - this.code = (byte)networkCode; - this.success = success; - } - - public byte getNetworkCode() { - return this.code; - } - - public boolean isSuccess() { - return this.success; - } - - public boolean isError() { - return ! this.success; - } - - public static WarpRequestStatus getFromNetworkCode(byte code) { - for(WarpRequestStatus value: WarpRequestStatus.values()) { - if(value.code == code) return value; - } - return UNKNOWN; - } - -} diff --git a/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapClientProxy.java b/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapClientProxy.java index 8fc067ca..18c0e28f 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapClientProxy.java +++ b/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapClientProxy.java @@ -25,8 +25,8 @@ import net.minecraftforge.fml.common.event.FMLServerStartingEvent; import net.minecraftforge.fml.relauncher.Side; import net.smyler.smylib.SmyLib; -import net.smyler.smylib.game.GameClient; import net.smyler.smylib.game.WrappedMinecraft; +import net.smyler.terramap.Terramap; import javax.imageio.ImageIO; @@ -39,26 +39,26 @@ public Side getSide() { @Override public void preInit(FMLPreInitializationEvent event) { - TerramapMod.logger.debug("Terramap client pre-init"); + Terramap.instance().logger().debug("Terramap client pre-init"); TerramapNetworkManager.registerHandlers(Side.CLIENT); if (!ImageIO.getImageReadersBySuffix("webp").hasNext()) { - TerramapMod.logger.warn("ImageIO does not have WebP support, triggering a plugin scan!"); + Terramap.instance().logger().warn("ImageIO does not have WebP support, triggering a plugin scan!"); ImageIO.scanForPlugins(); if (ImageIO.getImageReadersBySuffix("webp").hasNext()) { - TerramapMod.logger.info("Found a WebP ImageIO reader."); + Terramap.instance().logger().info("Found a WebP ImageIO reader."); } else { - TerramapMod.logger.error("Could not find a WebP ImageIO reader! WebP will not be supported."); + Terramap.instance().logger().error("Could not find a WebP ImageIO reader! WebP will not be supported."); } } } @Override public void init(FMLInitializationEvent event) { - TerramapMod.logger.debug("Terramap client init"); + Terramap.instance().logger().debug("Terramap client init"); WrappedMinecraft game = new WrappedMinecraft(Minecraft.getMinecraft()); MinecraftForge.EVENT_BUS.register(HudScreen.class); MinecraftForge.EVENT_BUS.register(game); - SmyLib.initializeGameClient(game, TerramapMod.logger); + SmyLib.initializeGameClient(game, Terramap.instance().logger()); if ("true".equals(System.getProperty("terramap.showTestScreen"))) { game.showTestScreen(); } @@ -90,13 +90,13 @@ public GameType getGameMode(EntityPlayer e) { NetworkPlayerInfo i = connection.getPlayerInfo(e.getUniqueID()); if(i != null) return i.getGameType(); } - TerramapMod.logger.error("Failed to determine player gamemode."); + Terramap.instance().logger().error("Failed to determine player gamemode."); return GameType.NOT_SET; } @Override public void onConfigChanged(OnConfigChangedEvent event) { - if (event.getModID().equals(TerramapMod.MODID)) { + if (event.getModID().equals(Terramap.MOD_ID)) { if(TerramapMod.proxy.isClient() && HudScreen.getContent() != null) { HudScreenHandler.updateMinimap(); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapServerProxy.java b/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapServerProxy.java index def16acf..f2a2c4ef 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapServerProxy.java +++ b/forge/src/main/java/fr/thesmyler/terramap/proxy/TerramapServerProxy.java @@ -1,6 +1,5 @@ package fr.thesmyler.terramap.proxy; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.command.TerrashowCommand; import fr.thesmyler.terramap.command.TilesetReloadCommand; import fr.thesmyler.terramap.eventhandlers.ServerTerramapEventHandler; @@ -14,6 +13,7 @@ import net.minecraftforge.fml.common.event.FMLPreInitializationEvent; import net.minecraftforge.fml.common.event.FMLServerStartingEvent; import net.minecraftforge.fml.relauncher.Side; +import net.smyler.terramap.Terramap; public class TerramapServerProxy extends TerramapProxy { @@ -24,13 +24,13 @@ public Side getSide() { @Override public void preInit(FMLPreInitializationEvent event) { - TerramapMod.logger.debug("Terramap server pre-init"); + Terramap.instance().logger().debug("Terramap server pre-init"); TerramapNetworkManager.registerHandlers(Side.SERVER); } @Override public void init(FMLInitializationEvent event) { - TerramapMod.logger.debug("Terramap server init"); + Terramap.instance().logger().debug("Terramap server init"); MinecraftForge.EVENT_BUS.register(new ServerTerramapEventHandler()); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/saving/client/ClientSaveManager.java b/forge/src/main/java/fr/thesmyler/terramap/saving/client/ClientSaveManager.java index a37562b5..bd5f4450 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/saving/client/ClientSaveManager.java +++ b/forge/src/main/java/fr/thesmyler/terramap/saving/client/ClientSaveManager.java @@ -1,12 +1,8 @@ package fr.thesmyler.terramap.saving.client; import com.google.gson.Gson; -import com.google.gson.GsonBuilder; import net.smyler.smylib.game.MinecraftServerInfo; -import fr.thesmyler.terramap.TerramapMod; -import fr.thesmyler.terramap.util.json.EarthGeneratorSettingsAdapter; -import net.buildtheearth.terraplusplus.generator.EarthGeneratorSettings; -import net.minecraft.client.multiplayer.ServerData; +import net.smyler.terramap.Terramap; import java.io.*; import java.nio.file.Path; @@ -25,24 +21,22 @@ public class ClientSaveManager { private Path worldDirectory; private Path serverDirectory; private Path proxyDirectory; + private final Gson gson; private static final String EXTENSION = ".json"; private static final String DEFAULT_SAVE_PATH = "/assets/terramap/defaultstate.json"; - private static final Gson GSON = new GsonBuilder() - .registerTypeAdapter(EarthGeneratorSettings.class, new EarthGeneratorSettingsAdapter()) - .setPrettyPrinting() - .create(); /** * Constructs a new {@link ClientSaveManager} given a save directory. * * @param saveDirectory a path to a directory where data will be saved */ - public ClientSaveManager(Path saveDirectory) { + public ClientSaveManager(Path saveDirectory, Gson gson) { this.saveDirectory = saveDirectory.toAbsolutePath(); this.worldDirectory = this.saveDirectory.resolve("worlds"); this.serverDirectory = this.saveDirectory.resolve("servers"); this.proxyDirectory = this.saveDirectory.resolve("proxies"); + this.gson = gson; } /** @@ -58,8 +52,8 @@ public SavedClientState loadWorldState(UUID worldUUID) { } /** - * Loads a {@link SavedClientState} associated with a specific server, given the server's {@link ServerData}. - * This method will usually be used when a remote world cannot be uniquely identified and we can only identify the server. + * Loads a {@link SavedClientState} associated with a specific server, given the server's {@link MinecraftServerInfo}. + * This method will usually be used when a remote world cannot be uniquely identified, and we can only identify the server. * * @param serverInfo the information of the server to retrieve the save for * @@ -88,14 +82,14 @@ public SavedClientState loadProxyState(UUID proxyUUID) { public SavedClientState getDefaultState() { InputStream stream = this.getClass().getResourceAsStream(DEFAULT_SAVE_PATH); if (stream == null) { - TerramapMod.logger.error("Missing internal resource: default client state"); + Terramap.instance().logger().error("Missing internal resource: default client state"); return new SavedClientState(); } try (InputStreamReader reader = new InputStreamReader(stream)) { - return GSON.fromJson(reader, SavedClientState.class); + return this.gson.fromJson(reader, SavedClientState.class); } catch (IOException e) { - TerramapMod.logger.error("Failed to read internal default map state"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to read internal default map state"); + Terramap.instance().logger().catching(e); return new SavedClientState(); } } @@ -113,14 +107,14 @@ public void saveWorldState(UUID worldUUID, SavedClientState state) { } /** - * Saves a {@link SavedClientState} associated with a specific server, given the server's {@link ServerData}. - * This method will usually be used when a remote world cannot be uniquely identified and we can only identify the server. + * Saves a {@link SavedClientState} associated with a specific server, given the server's {@link MinecraftServerInfo}. + * This method will usually be used when a remote world cannot be uniquely identified, and we can only identify the server. * * @param serverData the information of the server to retrieve the save for * @param state the state to save */ - public void saveServerState(ServerData serverData, SavedClientState state) { - this.saveStateToPath(this.serverDirectory.resolve(serverData.serverIP + EXTENSION), state); + public void saveServerState(MinecraftServerInfo serverData, SavedClientState state) { + this.saveStateToPath(this.serverDirectory.resolve(serverData.host + EXTENSION), state); } /** @@ -147,31 +141,31 @@ public void createDirectoryIfNecessary() throws IOException { private SavedClientState loadFromPath(Path path) { try (FileReader reader = new FileReader(path.toFile())) { - return GSON.fromJson(reader, SavedClientState.class); + return this.gson.fromJson(reader, SavedClientState.class); } catch (FileNotFoundException ignored) { // Let's not spam the console when it's just a new save. } catch (IOException e) { - TerramapMod.logger.error("Failed to read a saved client state, will fallback to a new one"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to read a saved client state, will fallback to a new one"); + Terramap.instance().logger().catching(e); } return this.getDefaultState(); } private void saveStateToPath(Path path, SavedClientState state) { try (FileWriter writer = new FileWriter(path.toFile())) { - GSON.toJson(state, writer); + this.gson.toJson(state, writer); } catch (IOException e) { - TerramapMod.logger.error("Failed to save a client state"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to save a client state"); + Terramap.instance().logger().catching(e); } } private Path prepareDirectory(Path directory) throws IOException { if (!exists(directory)) { - TerramapMod.logger.debug("Created directory " + directory); + Terramap.instance().logger().debug("Created directory {}", directory); createDirectories(directory); } else if (!isDirectory(directory) || ! isWritable(directory)) { - TerramapMod.logger.error(directory + " exists and is not a directory, or is not writeable. Terramap will fallback to a temporary directory instead."); + Terramap.instance().logger().error("{} exists and is not a directory, or is not writeable. Terramap will fallback to a temporary directory instead.", directory); directory = createTempDirectory(directory, "terramap"); directory.toFile().deleteOnExit(); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/saving/server/TerramapServerPreferences.java b/forge/src/main/java/fr/thesmyler/terramap/saving/server/TerramapServerPreferences.java index 250f91d0..08c6cf88 100644 --- a/forge/src/main/java/fr/thesmyler/terramap/saving/server/TerramapServerPreferences.java +++ b/forge/src/main/java/fr/thesmyler/terramap/saving/server/TerramapServerPreferences.java @@ -8,13 +8,11 @@ import java.util.Map; import java.util.UUID; -import com.google.gson.Gson; -import com.google.gson.GsonBuilder; import com.google.gson.JsonSyntaxException; -import fr.thesmyler.terramap.TerramapMod; import fr.thesmyler.terramap.TerramapConfig; import net.minecraft.world.WorldServer; +import net.smyler.terramap.Terramap; /** * @@ -30,7 +28,6 @@ public class TerramapServerPreferences { private static boolean loggedDebugError = false; private static long lastErrorLog = Long.MIN_VALUE; - private static final Gson GSON = new GsonBuilder().setPrettyPrinting().create(); /** * Tells whether the given player should be visible on the map on a given world @@ -48,8 +45,8 @@ public static boolean shouldDisplayPlayer(WorldServer world, UUID uuid) { } } catch(Exception e) { if(!loggedDebugError) { - TerramapMod.logger.error("Failed to get player display preferences. This error will only be displayed once."); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to get player display preferences. This error will only be displayed once."); + Terramap.instance().logger().catching(e); loggedDebugError = true; } return TerramapConfig.SERVER.playersDisplayDefault; @@ -75,8 +72,8 @@ public static void setShouldDisplayPlayer(WorldServer world, UUID uuid, boolean } saveWorldPreferences(world); } catch(Exception e) { - TerramapMod.logger.error("Failed to set player display preferences! See stack trace:"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to set player display preferences! See stack trace:"); + Terramap.instance().logger().catching(e); } } @@ -94,12 +91,12 @@ public static UUID getWorldUUID(WorldServer world) { uuid = UUID.randomUUID(); prefs.world_uuid = uuid; saveWorldPreferences(world); - TerramapMod.logger.info("Generated uuid " + uuid + " for world " + world.getSaveHandler().getWorldDirectory().getName()); + Terramap.instance().logger().info("Generated uuid {} for world {}", uuid, world.getSaveHandler().getWorldDirectory().getName()); } return uuid; } } catch(Exception e) { - TerramapMod.logger.warn("Failed to get world UUID, using 0 instead!"); + Terramap.instance().logger().warn("Failed to get world UUID, using 0 instead!"); } return new UUID(0, 0); } @@ -111,7 +108,7 @@ public static void unloadWorldPreferences(WorldServer world) { TerramapServerPreferences.preferences.remove(file.getAbsolutePath()); } } catch(Exception e) { - TerramapMod.logger.warn("Failed to unload a world server preferences"); + Terramap.instance().logger().warn("Failed to unload a world server preferences"); } } @@ -131,8 +128,8 @@ public static void saveWorldPreferences(WorldServer world) { } catch(Exception e) { long t = System.currentTimeMillis(); if(t > lastErrorLog + 10000) { - TerramapMod.logger.error("Failed to save server preferences"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to save server preferences"); + Terramap.instance().logger().catching(e); lastErrorLog = t; } } @@ -153,8 +150,8 @@ public static void saveAllPreferences() { } catch(Exception e) { long t = System.currentTimeMillis(); if(t > lastErrorLog + 10000) { - TerramapMod.logger.error("Failed to save server preferences"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to save server preferences"); + Terramap.instance().logger().catching(e); lastErrorLog = t; } } @@ -171,14 +168,14 @@ public static void loadWorldPreferences(WorldServer world) { if(fileToLoad.exists()) { try { String text = String.join("\n", Files.readAllLines(fileToLoad.toPath(), Charset.defaultCharset())); - preferences = GSON.fromJson(text, WorldPreferences.class); + preferences = Terramap.instance().gsonPretty().fromJson(text, WorldPreferences.class); } catch (IOException | JsonSyntaxException e) { - TerramapMod.logger.error("Failed to load server preference file, setting to default"); - TerramapMod.logger.catching(e); + Terramap.instance().logger().error("Failed to load server preference file, setting to default"); + Terramap.instance().logger().catching(e); preferences = new WorldPreferences(); } } else { - TerramapMod.logger.info("Loaded new empty server preferences as file did not exist"); + Terramap.instance().logger().info("Loaded new empty server preferences as file did not exist"); } synchronized(TerramapServerPreferences.preferences) { TerramapServerPreferences.preferences.put(fileToLoad.getAbsolutePath(), preferences); @@ -186,7 +183,7 @@ public static void loadWorldPreferences(WorldServer world) { } private static void save(File file, WorldPreferences preferences) throws IOException { - String str = GSON.toJson(preferences); + String str = Terramap.instance().gsonPretty().toJson(preferences); Files.write(file.toPath(), str.getBytes(Charset.defaultCharset())); } diff --git a/forge/src/main/java/fr/thesmyler/terramap/warp/Warp.java b/forge/src/main/java/fr/thesmyler/terramap/warp/Warp.java deleted file mode 100644 index 556f4e19..00000000 --- a/forge/src/main/java/fr/thesmyler/terramap/warp/Warp.java +++ /dev/null @@ -1,100 +0,0 @@ -package fr.thesmyler.terramap.warp; - -import java.util.HashMap; -import java.util.Map; -import java.util.Set; - -import fr.thesmyler.terramap.network.NetworkUtil; -import io.netty.buffer.ByteBuf; - -/** - * - * @author Smyler - * - * TODO Implement warps - * - */ -public class Warp { - - private final Map properties = new HashMap<>(); - - public Warp(String id) { - this.setProperty("id", id); - } - - public String getId() { - return this.getProperty("id"); - } - - public boolean hasProperty(String key) { - return this.properties.containsKey(key); - } - - public String getProperty(String property) { - return this.properties.getOrDefault(property, ""); - } - - public void setProperty(String key, String value) { - if(value == null || value.length() == 0) { - this.properties.remove(key); - } else { - this.properties.put(key, value); - } - } - - public Set getPropertyKeys() { - return this.properties.keySet(); - } - - /** - * Returns a warp with the same id as this one and the same properties as this one for the specified ones - * - * @param properties - * @return - */ - public Warp getCopyWithStrippedProperties(String... properties) { - Warp warp = new Warp(this.getId()); - for(String key: properties) { - warp.setProperty(key, this.getProperty(key)); - } - return warp; - } - - public void encodeToByteBuf(ByteBuf buf) { - buf.writeInt(this.properties.size() - 1); // Id is assumed - NetworkUtil.encodeStringToByteBuf(this.getId(), buf); - for(String key: this.properties.keySet()) { - if(key.equals("id")) continue; - NetworkUtil.encodeStringToByteBuf(key, buf); - NetworkUtil.encodeStringToByteBuf(this.properties.get(key), buf); - } - } - - public void encodeToByteBuf(ByteBuf buf, String ... properties) { - Map validProperties = new HashMap<>(); - for(String key: properties) { - if(!key.equals("id") && this.properties.containsKey(key)) { - validProperties.put(key, this.getProperty(key)); - } - } - buf.writeInt(validProperties.size()); - NetworkUtil.encodeStringToByteBuf(this.getId(), buf); - for(String key: validProperties.keySet()) { - NetworkUtil.encodeStringToByteBuf(key, buf); - NetworkUtil.encodeStringToByteBuf(validProperties.get(key), buf); - } - } - - public static Warp readWarpFromByteBuf(ByteBuf buf) { - int keyCount = buf.readInt(); - String id = NetworkUtil.decodeStringFromByteBuf(buf); - Warp warp = new Warp(id); - for(int i=0; i get(String url) { + CompletableFuture future = Http.get(url); + CompletableFuture result = future.thenApply(ByteBufUtil::getBytes); + result.exceptionally(t -> { + if (t instanceof CancellationException) { + System.out.println("Was cancelled"); + } + future.cancel(true); + return null; + }); + return result; + } + + @Override + public void setMaxConcurrentRequests(String host, int maxConcurrentRequests) { + Http.setMaximumConcurrentRequestsTo(host, maxConcurrentRequests); + } + +} diff --git a/forge/src/test/java/fr/thesmyler/terramap/TerramapTest.java b/forge/src/test/java/fr/thesmyler/terramap/TerramapTest.java index b78eed0e..86cc1f04 100644 --- a/forge/src/test/java/fr/thesmyler/terramap/TerramapTest.java +++ b/forge/src/test/java/fr/thesmyler/terramap/TerramapTest.java @@ -2,16 +2,24 @@ import fr.thesmyler.terramap.maps.raster.MapStylesLibrary; import net.smyler.smylib.SmyLibTest; +import net.smyler.terramap.Terramap; import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.BeforeEach; -public class TerramapTest extends SmyLibTest { +public class TerramapTest extends SmyLibTest implements Terramap { + private final Logger logger = LogManager.getLogger("Terramap unit test"); @BeforeEach public void initTerramap() { - TerramapMod.logger = LogManager.getLogger("Terramap unit test"); + Terramap.InstanceHolder.setInstance(this); MapStylesLibrary.reload(); TerramapClientContext.resetContext(); } + @Override + public Logger logger() { + return this.logger; + } + } diff --git a/smylib/testing/src/main/java/net/smyler/smylib/gui/DummyGlState.java b/smylib/testing/src/main/java/net/smyler/smylib/gui/DummyGlState.java index 71e62edf..77376e56 100644 --- a/smylib/testing/src/main/java/net/smyler/smylib/gui/DummyGlState.java +++ b/smylib/testing/src/main/java/net/smyler/smylib/gui/DummyGlState.java @@ -36,4 +36,29 @@ public void disableColorLogic() { } + @Override + public void pushViewMatrix() { + + } + + @Override + public void rotate(double angle) { + + } + + @Override + public void translate(double x, double y) { + + } + + @Override + public void scale(double x, double y) { + + } + + @Override + public void popViewMatrix() { + + } + }