aboutsummaryrefslogtreecommitdiff
path: root/libraries/launcher/org
diff options
context:
space:
mode:
authorTheKodeToad <TheKodeToad@proton.me>2022-11-08 17:51:18 +0000
committerTheKodeToad <TheKodeToad@proton.me>2022-11-08 17:51:18 +0000
commit32c2ad2bbd087b83fe5e1cfe03926410ec95bcca (patch)
tree7e532089643eaab82b84a28ae974e23535ec30fa /libraries/launcher/org
parentf2ca9a6b319ad0ade04837f6830e682bc86c01a2 (diff)
downloadPrismLauncher-32c2ad2bbd087b83fe5e1cfe03926410ec95bcca.tar.gz
PrismLauncher-32c2ad2bbd087b83fe5e1cfe03926410ec95bcca.tar.bz2
PrismLauncher-32c2ad2bbd087b83fe5e1cfe03926410ec95bcca.zip
A lot more cleanup
Signed-off-by: TheKodeToad <TheKodeToad@proton.me>
Diffstat (limited to 'libraries/launcher/org')
-rw-r--r--libraries/launcher/org/prismlauncher/EntryPoint.java105
-rw-r--r--libraries/launcher/org/prismlauncher/exception/ParameterNotFoundException.java22
-rw-r--r--libraries/launcher/org/prismlauncher/exception/ParseException.java26
-rw-r--r--libraries/launcher/org/prismlauncher/launcher/Launcher.java3
-rw-r--r--libraries/launcher/org/prismlauncher/launcher/impl/AbstractLauncher.java48
-rw-r--r--libraries/launcher/org/prismlauncher/launcher/impl/StandardLauncher.java38
-rw-r--r--libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyFrame.java99
-rw-r--r--libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyLauncher.java53
-rw-r--r--libraries/launcher/org/prismlauncher/utils/Parameters.java23
-rw-r--r--libraries/launcher/org/prismlauncher/utils/ReflectionUtils.java103
-rw-r--r--libraries/launcher/org/prismlauncher/utils/StringUtils.java11
-rw-r--r--libraries/launcher/org/prismlauncher/utils/logging/Level.java11
-rw-r--r--libraries/launcher/org/prismlauncher/utils/logging/Log.java52
-rw-r--r--libraries/launcher/org/prismlauncher/utils/logging/LogPrintStream.java99
14 files changed, 341 insertions, 352 deletions
diff --git a/libraries/launcher/org/prismlauncher/EntryPoint.java b/libraries/launcher/org/prismlauncher/EntryPoint.java
index 34e65672..f6567468 100644
--- a/libraries/launcher/org/prismlauncher/EntryPoint.java
+++ b/libraries/launcher/org/prismlauncher/EntryPoint.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
@@ -56,7 +55,6 @@
package org.prismlauncher;
import java.io.BufferedReader;
-import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
@@ -70,63 +68,40 @@ import org.prismlauncher.utils.logging.Log;
public final class EntryPoint {
- private EntryPoint() {
- }
-
public static void main(String[] args) {
- ExitCode exitCode = listen();
+ ExitCode code = listen();
- if (exitCode != ExitCode.NORMAL) {
- Log.fatal("Exiting with " + exitCode);
+ if (code != ExitCode.NORMAL) {
+ Log.fatal("Exiting with " + code);
- System.exit(exitCode.numericalCode);
- }
- }
-
- private static PreLaunchAction parseLine(String input, Parameters params) throws ParseException {
- if (input.isEmpty())
- return PreLaunchAction.PROCEED;
-
- if ("launch".equalsIgnoreCase(input))
- return PreLaunchAction.LAUNCH;
- else if ("abort".equalsIgnoreCase(input))
- return PreLaunchAction.ABORT;
- else {
- String[] pair = StringUtils.splitStringPair(' ', input);
-
- if (pair == null)
- throw new ParseException(String.format(
- "Could not split input string '%s' by space. All input provided from stdin must be either 'launch', 'abort', or "
- + "in the format '[param name] [param]'.",
- input));
-
- params.add(pair[0], pair[1]);
-
- return PreLaunchAction.PROCEED;
+ System.exit(code.numeric);
}
}
private static ExitCode listen() {
- Parameters parameters = new Parameters();
- PreLaunchAction preLaunchAction = PreLaunchAction.PROCEED;
+ Parameters params = new Parameters();
+ PreLaunchAction action = PreLaunchAction.PROCEED;
try (BufferedReader reader = new BufferedReader(new InputStreamReader(System.in, StandardCharsets.UTF_8))) {
String line;
- while (preLaunchAction == PreLaunchAction.PROCEED) {
+ while (action == PreLaunchAction.PROCEED) {
if ((line = reader.readLine()) != null)
- preLaunchAction = parseLine(line, parameters);
+ action = parseLine(line, params);
else
- preLaunchAction = PreLaunchAction.ABORT;
+ action = PreLaunchAction.ABORT;
}
- } catch (IOException | ParseException e) {
- Log.fatal("Launcher abort due to exception", e);
+ } catch (IllegalArgumentException e) {
+ Log.fatal("Aborting due to wrong argument", e);
return ExitCode.ILLEGAL_ARGUMENT;
+ } catch (Throwable e) {
+ Log.fatal("Aborting due to exception", e);
+
+ return ExitCode.ABORT;
}
- // Main loop
- if (preLaunchAction == PreLaunchAction.ABORT) {
+ if (action == PreLaunchAction.ABORT) {
Log.fatal("Launch aborted by the launcher");
return ExitCode.ABORT;
@@ -134,33 +109,28 @@ public final class EntryPoint {
try {
Launcher launcher;
- String type = parameters.getString("launcher");
+ String type = params.getString("launcher");
switch (type) {
case "standard":
- launcher = new StandardLauncher(parameters);
+ launcher = new StandardLauncher(params);
break;
+
case "legacy":
- launcher = new LegacyLauncher(parameters);
+ launcher = new LegacyLauncher(params);
break;
+
default:
throw new IllegalArgumentException("Invalid launcher type: " + type);
}
- Log.launcher("Using " + type + " launcher");
- Log.blankLine();
-
launcher.launch();
return ExitCode.NORMAL;
} catch (IllegalArgumentException e) {
- Log.fatal("Wrong argument", e);
+ Log.fatal("Illegal argument", e);
return ExitCode.ILLEGAL_ARGUMENT;
- } catch (ReflectiveOperationException e) {
- Log.fatal("Caught reflection exception from launcher", e);
-
- return ExitCode.ERROR;
} catch (Throwable e) {
Log.fatal("Exception caught from launcher", e);
@@ -168,6 +138,29 @@ public final class EntryPoint {
}
}
+ private static PreLaunchAction parseLine(String input, Parameters params) throws ParseException {
+ switch (input) {
+ case "":
+ break;
+
+ case "launch":
+ return PreLaunchAction.LAUNCH;
+
+ case "abort":
+ return PreLaunchAction.ABORT;
+
+ default:
+ String[] pair = StringUtils.splitStringPair(' ', input);
+
+ if (pair == null)
+ throw new ParseException(input, "[key] [value]");
+
+ params.add(pair[0], pair[1]);
+ }
+
+ return PreLaunchAction.PROCEED;
+ }
+
private enum PreLaunchAction {
PROCEED, LAUNCH, ABORT
}
@@ -175,10 +168,10 @@ public final class EntryPoint {
private enum ExitCode {
NORMAL(0), ABORT(1), ERROR(2), ILLEGAL_ARGUMENT(65);
- private final int numericalCode;
+ private final int numeric;
- ExitCode(int numericalCode) {
- this.numericalCode = numericalCode;
+ ExitCode(int numeric) {
+ this.numeric = numeric;
}
}
diff --git a/libraries/launcher/org/prismlauncher/exception/ParameterNotFoundException.java b/libraries/launcher/org/prismlauncher/exception/ParameterNotFoundException.java
index 52c2a368..524076ff 100644
--- a/libraries/launcher/org/prismlauncher/exception/ParameterNotFoundException.java
+++ b/libraries/launcher/org/prismlauncher/exception/ParameterNotFoundException.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
@@ -42,23 +41,8 @@ public final class ParameterNotFoundException extends IllegalArgumentException {
private static final long serialVersionUID = 1L;
- public ParameterNotFoundException(String message, Throwable cause) {
- super(message, cause);
- }
-
- public ParameterNotFoundException(Throwable cause) {
- super(cause);
- }
-
- public ParameterNotFoundException(String message) {
- super(message);
- }
-
- public ParameterNotFoundException() {
- }
-
- public static ParameterNotFoundException forParameterName(String parameterName) {
- return new ParameterNotFoundException(String.format("Unknown parameter name '%s'", parameterName));
+ public ParameterNotFoundException(String key) {
+ super(String.format("Required parameter '%s' was not found", key));
}
}
diff --git a/libraries/launcher/org/prismlauncher/exception/ParseException.java b/libraries/launcher/org/prismlauncher/exception/ParseException.java
index 80709c56..4608fdd1 100644
--- a/libraries/launcher/org/prismlauncher/exception/ParseException.java
+++ b/libraries/launcher/org/prismlauncher/exception/ParseException.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
@@ -42,27 +41,8 @@ public final class ParseException extends IllegalArgumentException {
private static final long serialVersionUID = 1L;
- public ParseException(String message) {
- super(message);
- }
-
- public ParseException(String message, Throwable cause) {
- super(message, cause);
- }
-
- public ParseException(Throwable cause) {
- super(cause);
- }
-
- public ParseException() {
- }
-
- public static ParseException forInputString(String inputString) {
- return new ParseException(String.format("Could not parse input string '%s'", inputString));
- }
-
- public static ParseException forInputString(String inputString, Throwable cause) {
- return new ParseException(String.format("Could not parse input string '%s'", inputString), cause);
+ public ParseException(String input, String format) {
+ super(String.format("For input '%s' - should match '%s'", input, format));
}
}
diff --git a/libraries/launcher/org/prismlauncher/launcher/Launcher.java b/libraries/launcher/org/prismlauncher/launcher/Launcher.java
index 1a6577e0..049a83d8 100644
--- a/libraries/launcher/org/prismlauncher/launcher/Launcher.java
+++ b/libraries/launcher/org/prismlauncher/launcher/Launcher.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
diff --git a/libraries/launcher/org/prismlauncher/launcher/impl/AbstractLauncher.java b/libraries/launcher/org/prismlauncher/launcher/impl/AbstractLauncher.java
index 7ae7568c..585d55f1 100644
--- a/libraries/launcher/org/prismlauncher/launcher/impl/AbstractLauncher.java
+++ b/libraries/launcher/org/prismlauncher/launcher/impl/AbstractLauncher.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
@@ -55,21 +54,20 @@
package org.prismlauncher.launcher.impl;
+import java.util.ArrayList;
+import java.util.List;
+
import org.prismlauncher.exception.ParseException;
import org.prismlauncher.launcher.Launcher;
import org.prismlauncher.utils.Parameters;
import org.prismlauncher.utils.StringUtils;
-import java.util.ArrayList;
-import java.util.List;
-
public abstract class AbstractLauncher implements Launcher {
- private static final int DEFAULT_WINDOW_WIDTH = 854;
- private static final int DEFAULT_WINDOW_HEIGHT = 480;
+ private static final int DEFAULT_WINDOW_WIDTH = 854, DEFAULT_WINDOW_HEIGHT = 480;
// parameters, separated from ParamBucket
- protected final List<String> mcParams;
+ protected final List<String> gameArgs;
// secondary parameters
protected final int width, height;
@@ -79,34 +77,34 @@ public abstract class AbstractLauncher implements Launcher {
protected final String mainClassName;
protected AbstractLauncher(Parameters params) {
- this.mcParams = params.getList("param", new ArrayList<String>());
- this.mainClassName = params.getString("mainClass", "net.minecraft.client.Minecraft");
+ gameArgs = params.getList("param", new ArrayList<String>());
+ mainClassName = params.getString("mainClass", "net.minecraft.client.Minecraft");
- this.serverAddress = params.getString("serverAddress", null);
- this.serverPort = params.getString("serverPort", null);
+ serverAddress = params.getString("serverAddress", null);
+ serverPort = params.getString("serverPort", null);
String windowParams = params.getString("windowParams", null);
- this.maximize = "max".equalsIgnoreCase(windowParams);
+ if ("max".equals(windowParams) || windowParams == null) {
+ maximize = windowParams != null;
+
+ width = DEFAULT_WINDOW_WIDTH;
+ height = DEFAULT_WINDOW_HEIGHT;
+ } else {
+ maximize = false;
- if (windowParams != null && !"max".equalsIgnoreCase(windowParams)) {
String[] sizePair = StringUtils.splitStringPair('x', windowParams);
if (sizePair != null) {
try {
- this.width = Integer.parseInt(sizePair[0]);
- this.height = Integer.parseInt(sizePair[1]);
- } catch (NumberFormatException e) {
- throw new ParseException(String.format("Could not parse window parameters from '%s'", windowParams),
- e);
+ width = Integer.parseInt(sizePair[0]);
+ height = Integer.parseInt(sizePair[1]);
+ return;
+ } catch (NumberFormatException ignored) {
}
- } else {
- throw new ParseException(
- String.format("Invalid window size parameters '%s'. Format: [height]x[width]", windowParams));
}
- } else {
- this.width = DEFAULT_WINDOW_WIDTH;
- this.height = DEFAULT_WINDOW_HEIGHT;
+
+ throw new ParseException(windowParams, "[width]x[height]");
}
}
diff --git a/libraries/launcher/org/prismlauncher/launcher/impl/StandardLauncher.java b/libraries/launcher/org/prismlauncher/launcher/impl/StandardLauncher.java
index 0f6fcf34..9436ff15 100644
--- a/libraries/launcher/org/prismlauncher/launcher/impl/StandardLauncher.java
+++ b/libraries/launcher/org/prismlauncher/launcher/impl/StandardLauncher.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
@@ -55,11 +54,11 @@
package org.prismlauncher.launcher.impl;
+import java.lang.invoke.MethodHandle;
+
import org.prismlauncher.utils.Parameters;
import org.prismlauncher.utils.ReflectionUtils;
-import java.lang.invoke.MethodHandle;
-
public final class StandardLauncher extends AbstractLauncher {
public StandardLauncher(Parameters params) {
@@ -69,27 +68,24 @@ public final class StandardLauncher extends AbstractLauncher {
@Override
public void launch() throws Throwable {
// window size, title and state
-
- // FIXME: there is no good way to maximize the minecraft window from here.
- // the following often breaks linux screen setups
- // mcparams.add("--fullscreen");
-
- if (!this.maximize) {
- this.mcParams.add("--width");
- this.mcParams.add(Integer.toString(this.width));
- this.mcParams.add("--height");
- this.mcParams.add(Integer.toString(this.height));
+ // FIXME doesn't support maximisation
+ if (!maximize) {
+ gameArgs.add("--width");
+ gameArgs.add(Integer.toString(width));
+ gameArgs.add("--height");
+ gameArgs.add(Integer.toString(height));
}
- if (this.serverAddress != null) {
- this.mcParams.add("--server");
- this.mcParams.add(this.serverAddress);
- this.mcParams.add("--port");
- this.mcParams.add(this.serverPort);
+ if (serverAddress != null) {
+ gameArgs.add("--server");
+ gameArgs.add(serverAddress);
+ gameArgs.add("--port");
+ gameArgs.add(serverPort);
}
- MethodHandle method = ReflectionUtils.findMainMethod(this.mainClassName);
- method.invokeExact(this.mcParams.toArray(new String[0]));
+ // find and invoke the main method
+ MethodHandle method = ReflectionUtils.findMainMethod(mainClassName);
+ method.invokeExact(gameArgs.toArray(new String[0]));
}
}
diff --git a/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyFrame.java b/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyFrame.java
index 8ff64ced..c215e7fe 100644
--- a/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyFrame.java
+++ b/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyFrame.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 flow <flowlnlnln@gmail.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
@@ -55,13 +54,6 @@
package org.prismlauncher.launcher.impl.legacy;
-import net.minecraft.Launcher;
-
-import javax.imageio.ImageIO;
-import javax.swing.JFrame;
-
-import org.prismlauncher.utils.logging.Log;
-
import java.applet.Applet;
import java.awt.Dimension;
import java.awt.event.WindowAdapter;
@@ -75,6 +67,13 @@ import java.nio.file.Paths;
import java.nio.file.StandardCopyOption;
import java.util.List;
+import javax.imageio.ImageIO;
+import javax.swing.JFrame;
+
+import org.prismlauncher.utils.logging.Log;
+
+import net.minecraft.Launcher;
+
public final class LegacyFrame extends JFrame {
private static final long serialVersionUID = 1L;
@@ -84,85 +83,85 @@ public final class LegacyFrame extends JFrame {
public LegacyFrame(String title, Applet applet) {
super(title);
- this.launcher = new Launcher(applet);
+ launcher = new Launcher(applet);
- applet.setStub(this.launcher);
+ applet.setStub(launcher);
try {
- this.setIconImage(ImageIO.read(new File("icon.png")));
+ setIconImage(ImageIO.read(new File("icon.png")));
} catch (IOException e) {
- Log.error("Unable to read Minecraft icon", e);
+ Log.error("Failed to read window icon", e);
}
- this.addWindowListener(new ForceExitHandler());
+ addWindowListener(new ForceExitHandler());
}
public void start(String user, String session, int width, int height, boolean maximize, String serverAddress,
- String serverPort, boolean isDemo) {
+ String serverPort, boolean demo) {
// Implements support for launching in to multiplayer on classic servers using a
- // mpticket
- // file generated by an external program and stored in the instance's root
- // folder.
-
- Path mpticketFile = Paths.get(System.getProperty("user.dir"), "..", "mpticket");
+ // mpticket file generated by an external program and stored in the instance's
+ // root folder.
+ Path instanceFolder = Paths.get("..");
+ Path mpticket = instanceFolder.resolve("mpticket");
+ Path mpticketCorrupt = instanceFolder.resolve("mpticket.corrupt");
- Path mpticketFileCorrupt = Paths.get(System.getProperty("user.dir"), "..", "mpticket.corrupt");
-
- if (Files.exists(mpticketFile)) {
+ if (Files.exists(mpticket)) {
try {
- List<String> lines = Files.readAllLines(mpticketFile, StandardCharsets.UTF_8);
+ List<String> lines = Files.readAllLines(mpticket, StandardCharsets.UTF_8);
if (lines.size() < 3) {
- Files.move(mpticketFile, mpticketFileCorrupt, StandardCopyOption.REPLACE_EXISTING);
+ Files.move(mpticket, mpticketCorrupt, StandardCopyOption.REPLACE_EXISTING);
- Log.warning("Mpticket file is corrupted!");
+ Log.warning("mpticket file is corrupted");
} else {
// Assumes parameters are valid and in the correct order
- this.launcher.setParameter("server", lines.get(0));
- this.launcher.setParameter("port", lines.get(1));
- this.launcher.setParameter("mppass", lines.get(2));
+ launcher.setParameter("server", lines.get(0));
+ launcher.setParameter("port", lines.get(1));
+ launcher.setParameter("mppass", lines.get(2));
}
} catch (IOException e) {
- Log.error("Unable to read mpticket file", e);
+ Log.error("Failed to read mpticket file", e);
}
}
if (serverAddress != null) {
- this.launcher.setParameter("server", serverAddress);
- this.launcher.setParameter("port", serverPort);
+ launcher.setParameter("server", serverAddress);
+ launcher.setParameter("port", serverPort);
}
- this.launcher.setParameter("username", user);
- this.launcher.setParameter("sessionid", session);
- this.launcher.setParameter("stand-alone", "true"); // Show the quit button. TODO: why won't this work?
- this.launcher.setParameter("haspaid", "true"); // Some old versions need this for world saves to work.
- this.launcher.setParameter("demo", isDemo ? "true" : "false");
- this.launcher.setParameter("fullscreen", "false");
+ launcher.setParameter("username", user);
+ launcher.setParameter("sessionid", session);
+ launcher.setParameter("stand-alone", true); // Show the quit button. TODO: why won't this work?
+ launcher.setParameter("haspaid", true); // Some old versions need this for world saves to work.
+ launcher.setParameter("demo", demo);
+ launcher.setParameter("fullscreen", false);
- this.add(this.launcher);
+ add(launcher);
- this.launcher.setPreferredSize(new Dimension(width, height));
+ launcher.setPreferredSize(new Dimension(width, height));
- this.pack();
+ pack();
- this.setLocationRelativeTo(null);
- this.setResizable(true);
+ setLocationRelativeTo(null);
+ setResizable(true);
if (maximize)
setExtendedState(MAXIMIZED_BOTH);
- this.validate();
+ validate();
- this.launcher.init();
- this.launcher.start();
+ launcher.init();
+ launcher.start();
- this.setVisible(true);
+ setVisible(true);
}
private final class ForceExitHandler extends WindowAdapter {
@Override
public void windowClosing(WindowEvent event) {
+ // FIXME better solution
+
new Thread(new Runnable() {
@Override
public void run() {
@@ -177,9 +176,9 @@ public final class LegacyFrame extends JFrame {
}
}).start();
- if (LegacyFrame.this.launcher != null) {
- LegacyFrame.this.launcher.stop();
- LegacyFrame.this.launcher.destroy();
+ if (launcher != null) {
+ launcher.stop();
+ launcher.destroy();
}
// old minecraft versions can hang without this >_<
diff --git a/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyLauncher.java b/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyLauncher.java
index 5ffa9ec5..d349177b 100644
--- a/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyLauncher.java
+++ b/libraries/launcher/org/prismlauncher/launcher/impl/legacy/LegacyLauncher.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 flow <flowlnlnln@gmail.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
@@ -56,17 +55,17 @@
package org.prismlauncher.launcher.impl.legacy;
-import org.prismlauncher.launcher.impl.AbstractLauncher;
-import org.prismlauncher.utils.Parameters;
-import org.prismlauncher.utils.ReflectionUtils;
-import org.prismlauncher.utils.logging.Log;
-
import java.io.File;
import java.lang.invoke.MethodHandle;
import java.lang.reflect.Field;
import java.util.Collections;
import java.util.List;
+import org.prismlauncher.launcher.impl.AbstractLauncher;
+import org.prismlauncher.utils.Parameters;
+import org.prismlauncher.utils.ReflectionUtils;
+import org.prismlauncher.utils.logging.Log;
+
/**
* Used to launch old versions that support applets.
*/
@@ -75,51 +74,53 @@ public final class LegacyLauncher extends AbstractLauncher {
private final String user, session;
private final String title;
private final String appletClass;
- private final boolean usesApplet;
- private final String cwd;
+ private final boolean useApplet;
+ private final String gameDir;
public LegacyLauncher(Parameters params) {
super(params);
- this.user = params.getString("userName");
- this.session = params.getString("sessionId");
- this.title = params.getString("windowTitle", "Minecraft");
- this.appletClass = params.getString("appletClass", "net.minecraft.client.MinecraftApplet");
+ user = params.getString("userName");
+ session = params.getString("sessionId");
+ title = params.getString("windowTitle", "Minecraft");
+ appletClass = params.getString("appletClass", "net.minecraft.client.MinecraftApplet");
List<String> traits = params.getList("traits", Collections.<String>emptyList());
- this.usesApplet = !traits.contains("noapplet");
+ useApplet = !traits.contains("noapplet");
- this.cwd = System.getProperty("user.dir");
+ gameDir = System.getProperty("user.dir");
}
@Override
public void launch() throws Throwable {
- Class<?> main = ClassLoader.getSystemClassLoader().loadClass(this.mainClassName);
- Field gameDirField = ReflectionUtils.getMinecraftGameDirField(main);
+ Class<?> main = ClassLoader.getSystemClassLoader().loadClass(mainClassName);
+ Field gameDirField = ReflectionUtils.findMinecraftGameDirField(main);
if (gameDirField == null)
- Log.warning("Could not find Minecraft path field");
+ Log.warning("Could not find Minecraft folder field");
else {
gameDirField.setAccessible(true);
- gameDirField.set(null /* field is static, so instance is null */, new File(this.cwd));
+ gameDirField.set(null, new File(gameDir));
}
- if (this.usesApplet) {
- Log.launcher("Launching with applet wrapper...");
+ if (useApplet) {
+ System.setProperty("minecraft.applet.TargetDirectory", gameDir);
try {
- LegacyFrame window = new LegacyFrame(this.title, ReflectionUtils.createAppletClass(this.appletClass));
+ LegacyFrame window = new LegacyFrame(title, ReflectionUtils.createAppletClass(appletClass));
- window.start(this.user, this.session, this.width, this.height, this.maximize, this.serverAddress,
- this.serverPort, this.mcParams.contains("--demo"));
+ window.start(user, session, width, height, maximize, serverAddress, serverPort,
+ gameArgs.contains("--demo"));
return;
} catch (Throwable e) {
Log.error("Running applet wrapper failed with exception; falling back to main class", e);
}
}
- MethodHandle method = ReflectionUtils.findMainEntrypoint(main);
- method.invokeExact(this.mcParams.toArray(new String[0]));
+ // find and invoke the main method, this time without size parameters
+ // in all versions that support applets, these are ignored
+ MethodHandle method = ReflectionUtils.findMainMethod(main);
+ method.invokeExact(gameArgs.toArray(new String[0]));
}
}
diff --git a/libraries/launcher/org/prismlauncher/utils/Parameters.java b/libraries/launcher/org/prismlauncher/utils/Parameters.java
index 7af3c5e8..6365753e 100644
--- a/libraries/launcher/org/prismlauncher/utils/Parameters.java
+++ b/libraries/launcher/org/prismlauncher/utils/Parameters.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 icelimetea <fr3shtea@outlook.com>
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
@@ -55,40 +54,40 @@
package org.prismlauncher.utils;
-import org.prismlauncher.exception.ParameterNotFoundException;
-
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
+import org.prismlauncher.exception.ParameterNotFoundException;
+
public final class Parameters {
private final Map<String, List<String>> map = new HashMap<>();
public void add(String key, String value) {
- List<String> params = this.map.get(key);
+ List<String> params = map.get(key);
if (params == null) {
params = new ArrayList<>();
- this.map.put(key, params);
+ map.put(key, params);
}
params.add(value);
}
public List<String> getList(String key) throws ParameterNotFoundException {
- List<String> params = this.map.get(key);
+ List<String> params = map.get(key);
if (params == null)
- throw ParameterNotFoundException.forParameterName(key);
+ throw new ParameterNotFoundException(key);
return params;
}
public List<String> getList(String key, List<String> def) {
- List<String> params = this.map.get(key);
+ List<String> params = map.get(key);
if (params == null || params.isEmpty())
return def;
@@ -97,16 +96,16 @@ public final class Parameters {
}
public String getString(String key) throws ParameterNotFoundException {
- List<String> list = this.getList(key);
+ List<String> list = getList(key);
if (list.isEmpty())
- throw ParameterNotFoundException.forParameterName(key);
+ throw new ParameterNotFoundException(key);
return list.get(0);
}
public String getString(String key, String def) {
- List<String> params = this.map.get(key);
+ List<String> params = map.get(key);