From f60210089c328a6bfa695d42cfb2208d08e806e9 Mon Sep 17 00:00:00 2001 From: Barade Date: Sun, 16 Apr 2023 20:08:03 +0200 Subject: [PATCH 1/2] How to run/debug in IDE and load icons from data source --- README.md | 37 +++++++++++++++++++ .../warsmash/desktop/DesktopLauncher.java | 27 +++++++++++--- 2 files changed, 59 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index c4cd1fc1..b454ab02 100644 --- a/README.md +++ b/README.md @@ -20,6 +20,43 @@ https://discord.com/invite/ucjftZ7x7H 5. Remove the duplicate "META-INF/services/javax.imageio.spi.ImageReaderSpi" files that share the same name located in META-INF so that only the BLP related file is present 6. Save the JAR and exit 7zip *(This process will hopefully become easier in the future)* + +## How to run/debug in IDE +1. Use a working directory (e. g. the project root directory) to run Warsmash from the IDE. +1. Copy [warsmash.ini](./core/assets/warsmash.ini) file into the working directory. +2. Adapt all the file paths in section`[DataSources]` to your local Warcraft installation or other data sources and make sure that they all do exist and add the project directories [.\core\assets\resources](.\core\assets\resources) and [.\resources](.\resources) are included since they contain required files. +All relative paths must work for your working directory: + +```` +[DataSources] +Count=8 +// Reforged +Type00=CASC +Path00="C:\Program Files (x86)\Warcraft III" +Prefixes00=war3.w3mod,war3.w3mod\_deprecated.w3mod,war3.w3mod\_locales\enus.w3mod +// Warcraft III: Reign of Chaos +Type01=MPQ +Path01="D:\Warcraft III\war3.mpq" +// Warcraft III: The Frozen Throne +Type02=MPQ +Path02="D:\Warcraft III\War3x.mpq" +// Warcraft III: The Frozen Throne Language +Type03=MPQ +Path03="D:\Warcraft III\War3xlocal.mpq" +// Warcraft III: The Frozen Throne Patch +Type04=MPQ +Path04="D:\Warcraft III\War3Patch.mpq" +// Warsmash +Type05=Folder +Path05=".\core\assets\" +Type06=Folder +Path06=".\resources\" +Type07=Folder +Path07="." +```` + +4. Run/debug the method `com.etheller.warsmash.desktop.DesktopLauncher.main` with the options `-nolog -window -loadfile ` from your IDE to load your custom map file in windowed mode and print the logs into the console instead of a log file. + If the path to your .w3x file is relative, it has to be found from your working directory. ## Background and History My current codebase is running on Java 8 and the LibGDX game engine coupled with the port of the mdx-m3-viewer's engine. It contains: diff --git a/desktop/src/com/etheller/warsmash/desktop/DesktopLauncher.java b/desktop/src/com/etheller/warsmash/desktop/DesktopLauncher.java index 62aef566..172b987b 100644 --- a/desktop/src/com/etheller/warsmash/desktop/DesktopLauncher.java +++ b/desktop/src/com/etheller/warsmash/desktop/DesktopLauncher.java @@ -12,6 +12,8 @@ import java.io.PrintStream; import java.nio.FloatBuffer; +import com.etheller.warsmash.WarsmashGdxMapScreen; +import com.etheller.warsmash.datasources.DataSource; import org.lwjgl.BufferUtils; import org.lwjgl.openal.AL; import org.lwjgl.opengl.GL11; @@ -45,17 +47,13 @@ public class DesktopLauncher { public static void main(final String[] arg) { - System.out.println("You ran it."); + System.out.println("You ran it in working directory " + System.getProperty("user.dir")); final LwjglApplicationConfiguration config = new LwjglApplicationConfiguration(); config.useGL30 = true; config.gles30ContextMajorVersion = 3; config.gles30ContextMinorVersion = 3; // config.samples = 16; // config.vSyncEnabled = false; - config.addIcon("resources/Icon16.png", Files.FileType.Internal); - config.addIcon("resources/Icon32.png", Files.FileType.Internal); - config.addIcon("resources/Icon64.png", Files.FileType.Internal); - config.addIcon("resources/Icon128.png", Files.FileType.Internal); // config.foregroundFPS = 0; // config.backgroundFPS = 0; final DisplayMode desktopDisplayMode = LwjglApplicationConfiguration.getDesktopDisplayMode(); @@ -100,7 +98,26 @@ else if ((arg.length > (argIndex + 1)) && "-ini".equals(arg[argIndex])) { } loadExtensions(); final DataTable warsmashIni = loadWarsmashIni(iniPath); + + // Load icons: + DataSource codebase = WarsmashGdxMapScreen.parseDataSources(warsmashIni); + try { + config.addIcon(codebase.getFile("resources/Icon16.png").getAbsolutePath(), Files.FileType.Internal); + config.addIcon(codebase.getFile("resources/Icon32.png").getAbsolutePath(), Files.FileType.Internal); + config.addIcon(codebase.getFile("resources/Icon64.png").getAbsolutePath(), Files.FileType.Internal); + config.addIcon(codebase.getFile("resources/Icon128.png").getAbsolutePath(), Files.FileType.Internal); + } catch (final IOException e) { + e.printStackTrace(); + } + final Element emulatorConstants = warsmashIni.get("Emulator"); + + if (emulatorConstants == null) { + System.err.println("Missing entry \"Emulator\" in .ini file."); + + return; + } + WarsmashConstants.loadConstants(emulatorConstants, warsmashIni); if (fileToLoad != null) { From db75a7223bda354483b1e2d148cdad2b96a86ac3 Mon Sep 17 00:00:00 2001 From: Tamino Dauth Date: Tue, 25 Apr 2023 15:42:19 +0200 Subject: [PATCH 2/2] README --- README.md | 49 ++++++++++++++++++++++--------------------------- 1 file changed, 22 insertions(+), 27 deletions(-) diff --git a/README.md b/README.md index b454ab02..eb36a51d 100644 --- a/README.md +++ b/README.md @@ -21,42 +21,37 @@ https://discord.com/invite/ucjftZ7x7H 6. Save the JAR and exit 7zip *(This process will hopefully become easier in the future)* -## How to run/debug in IDE -1. Use a working directory (e. g. the project root directory) to run Warsmash from the IDE. -1. Copy [warsmash.ini](./core/assets/warsmash.ini) file into the working directory. -2. Adapt all the file paths in section`[DataSources]` to your local Warcraft installation or other data sources and make sure that they all do exist and add the project directories [.\core\assets\resources](.\core\assets\resources) and [.\resources](.\resources) are included since they contain required files. -All relative paths must work for your working directory: +## How to debug your map in any IDE + +It can be useful to debug your map with Warsmash in your IDE using breakpoints and other debugging features to improve Warsmash: + +1. Install Warcraft from Blizzard. +2. Install Java 17. +3. Clone the Warsmash repository. +4. Use a working directory (e. g. the project root directory of Warsmash) to run Warsmash from the IDE. +5. Copy [warsmash.ini](./core/assets/warsmash.ini) file into the working directory and adapt all the file paths in section`[DataSources]` to your local Warcraft installation or other data sources and make sure that they all do exist and add the project directories [.\core\assets\resources](.\core\assets\resources) and [.\resources](.\resources) are included since they contain required files. +All relative paths must work for your working directory. +This is an example for Warcraft III: Reforged: ```` [DataSources] -Count=8 -// Reforged +Count=4 +// Warcraft III: Reforged Type00=CASC Path00="C:\Program Files (x86)\Warcraft III" Prefixes00=war3.w3mod,war3.w3mod\_deprecated.w3mod,war3.w3mod\_locales\enus.w3mod -// Warcraft III: Reign of Chaos -Type01=MPQ -Path01="D:\Warcraft III\war3.mpq" -// Warcraft III: The Frozen Throne -Type02=MPQ -Path02="D:\Warcraft III\War3x.mpq" -// Warcraft III: The Frozen Throne Language -Type03=MPQ -Path03="D:\Warcraft III\War3xlocal.mpq" -// Warcraft III: The Frozen Throne Patch -Type04=MPQ -Path04="D:\Warcraft III\War3Patch.mpq" // Warsmash -Type05=Folder -Path05=".\core\assets\" -Type06=Folder -Path06=".\resources\" -Type07=Folder -Path07="." +Type01=Folder +Path01=".\core\assets\" +Type02=Folder +Path02=".\resources\" +// Working directory +Type03=Folder +Path03="." ```` -4. Run/debug the method `com.etheller.warsmash.desktop.DesktopLauncher.main` with the options `-nolog -window -loadfile ` from your IDE to load your custom map file in windowed mode and print the logs into the console instead of a log file. - If the path to your .w3x file is relative, it has to be found from your working directory. +7. Run/debug the method `com.etheller.warsmash.desktop.DesktopLauncher.main` with the options `-nolog -window -loadfile ` from your IDE to load your custom map file in windowed mode and print the logs into the console instead of a log file. + If the path to your .w3x file is relative, it has to be found from your working directory. ## Background and History My current codebase is running on Java 8 and the LibGDX game engine coupled with the port of the mdx-m3-viewer's engine. It contains: