aboutsummaryrefslogtreecommitdiff
path: root/libraries/launcher/org/prismlauncher/utils
diff options
context:
space:
mode:
Diffstat (limited to 'libraries/launcher/org/prismlauncher/utils')
-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
6 files changed, 169 insertions, 130 deletions
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);
if (params == null || params.isEmpty())
return def;
diff --git a/libraries/launcher/org/prismlauncher/utils/ReflectionUtils.java b/libraries/launcher/org/prismlauncher/utils/ReflectionUtils.java
index 3b299615..dd212ef9 100644
--- a/libraries/launcher/org/prismlauncher/utils/ReflectionUtils.java
+++ b/libraries/launcher/org/prismlauncher/utils/ReflectionUtils.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>
@@ -67,68 +66,57 @@ import org.prismlauncher.utils.logging.Log;
public final class ReflectionUtils {
- private ReflectionUtils() {
- }
+ private static final MethodHandles.Lookup LOOKUP = MethodHandles.lookup();
+ private static final ClassLoader LOADER = ClassLoader.getSystemClassLoader();
/**
- * Instantiate an applet class by name
- *
- * @param appletClassName The name of the applet class to resolve
+ * Construct a Java applet by its class name.
*
- * @return The instantiated applet class
- *
- * @throws ClassNotFoundException if the provided class name cannot be found
- * @throws NoSuchMethodException if the no-args constructor cannot be found
- * @throws IllegalAccessException if the constructor cannot be accessed via
- * method handles
- * @throws Throwable any exceptions from the class's constructor
+ * @param clazz The class name
+ * @return The applet instance
+ * @throws Throwable
*/
- public static Applet createAppletClass(String appletClassName) throws Throwable {
- Class<?> appletClass = ClassLoader.getSystemClassLoader().loadClass(appletClassName);
+ public static Applet createAppletClass(String clazz) throws Throwable {
+ Class<?> appletClass = LOADER.loadClass(clazz);
- MethodHandle appletConstructor = MethodHandles.lookup().findConstructor(appletClass,
- MethodType.methodType(void.class));
+ MethodHandle appletConstructor = LOOKUP.findConstructor(appletClass, MethodType.methodType(void.class));
return (Applet) appletConstructor.invoke();
}
/**
- * Finds a field that looks like a Minecraft base folder in a supplied class
- *
- * @param minecraftMainClass the class to scan
+ * Best guess of the game directory field within net.minecraft.client.Minecraft.
+ * Designed for legacy versions - newer versions do not use a static field.
*
- * @return The found field.
+ * @param clazz The class
+ * @return The first field matching criteria
*/
- public static Field getMinecraftGameDirField(Class<?> minecraftMainClass) {
+ public static Field findMinecraftGameDirField(Class<?> clazz) {
Log.debug("Resolving minecraft game directory field");
- // Field we're looking for is always
- // private static File obfuscatedName = null;
- for (Field field : minecraftMainClass.getDeclaredFields()) {
- // Has to be File
+
+ // search for private static File
+ for (Field field : clazz.getDeclaredFields()) {
if (field.getType() != File.class) {
continue;
}
int fieldModifiers = field.getModifiers();
- // Must be static
if (!Modifier.isStatic(fieldModifiers)) {
Log.debug("Rejecting field " + field.getName() + " because it is not static");
continue;
}
- // Must be private
if (!Modifier.isPrivate(fieldModifiers)) {
Log.debug("Rejecting field " + field.getName() + " because it is not private");
continue;
}
- // Must not be final
if (Modifier.isFinal(fieldModifiers)) {
Log.debug("Rejecting field " + field.getName() + " because it is final");
continue;
}
- Log.debug("Identified field " + field.getName() + " to match conditions for minecraft game directory field");
+ Log.debug("Identified field " + field.getName() + " to match conditions for game directory field");
return field;
}
@@ -137,51 +125,30 @@ public final class ReflectionUtils {
}
/**
- * Resolve main entrypoint and returns method handle for it.
- * <p>
- * Resolves a method that matches the following signature <code>
- * public static void main(String[] args) {
- * <p>
- * }
- * </code>
- *
- * @param entrypointClass The entrypoint class to resolve the method from
- *
- * @return The method handle for the resolved entrypoint
+ * Gets the main method within a class.
*
- * @throws NoSuchMethodException If no method matching the correct signature
- * can be found
- * @throws IllegalAccessException If method handles cannot access the entrypoint
+ * @param clazz The class
+ * @return A method matching the descriptor of a main method
+ * @throws ClassNotFoundException
+ * @throws NoSuchMethodException
+ * @throws IllegalAccessException
*/
- public static MethodHandle findMainEntrypoint(Class<?> entrypointClass)
- throws NoSuchMethodException, IllegalAccessException {
- return MethodHandles.lookup().findStatic(entrypointClass, "main",
- MethodType.methodType(void.class, String[].class));
+ public static MethodHandle findMainMethod(Class<?> clazz) throws NoSuchMethodException, IllegalAccessException {
+ return LOOKUP.findStatic(clazz, "main", MethodType.methodType(void.class, String[].class));
}
/**
- * Resolve main entrypoint and returns method handle for it.
- * <p>
- * Resolves a method that matches the following signature <code>
- * public static void main(String[] args) {
- * <p>
- * }
- * </code>
- *
- * @param entrypointClassName The name of the entrypoint class to resolve the
- * method from
- *
- * @return The method handle for the resolved entrypoint
+ * Gets the main method within a class by its name.
*
- * @throws ClassNotFoundException If a class cannot be found with the provided
- * name
- * @throws NoSuchMethodException If no method matching the correct signature
- * can be found
- * @throws IllegalAccessException If method handles cannot access the entrypoint
+ * @param clazz The class name
+ * @return A method matching the descriptor of a main method
+ * @throws ClassNotFoundException
+ * @throws NoSuchMethodException
+ * @throws IllegalAccessException
*/
- public static MethodHandle findMainMethod(String entrypointClassName)
+ public static MethodHandle findMainMethod(String clazz)
throws ClassNotFoundException, NoSuchMethodException, IllegalAccessException {
- return findMainEntrypoint(ClassLoader.getSystemClassLoader().loadClass(entrypointClassName));
+ return findMainMethod(LOADER.loadClass(clazz));
}
}
diff --git a/libraries/launcher/org/prismlauncher/utils/StringUtils.java b/libraries/launcher/org/prismlauncher/utils/StringUtils.java
index a371b0cb..dfd1634b 100644
--- a/libraries/launcher/org/prismlauncher/utils/StringUtils.java
+++ b/libraries/launcher/org/prismlauncher/utils/StringUtils.java
@@ -1,7 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * Prism Launcher
- *
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 solonovamax <solonovamax@12oclockpoint.com>
*
* This program is free software: you can redistribute it and/or modify
@@ -38,15 +37,13 @@ package org.prismlauncher.utils;
public final class StringUtils {
- private StringUtils() {
- }
+ public static String[] splitStringPair(char splitChar, String str) {
+ int splitPoint = str.indexOf(splitChar);
- public static String[] splitStringPair(char splitChar, String input) {
- int splitPoint = input.indexOf(splitChar);
if (splitPoint == -1)
return null;
- return new String[] { input.substring(0, splitPoint), input.substring(splitPoint + 1) };
+ return new String[] { str.substring(0, splitPoint), str.substring(splitPoint + 1) };
}
}
diff --git a/libraries/launcher/org/prismlauncher/utils/logging/Level.java b/libraries/launcher/org/prismlauncher/utils/logging/Level.java
index 330cec28..552b0b55 100644
--- a/libraries/launcher/org/prismlauncher/utils/logging/Level.java
+++ b/libraries/launcher/org/prismlauncher/utils/logging/Level.java
@@ -1,6 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * PolyMC - Minecraft Launcher
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
*
* This program is free software: you can redistribute it and/or modify
@@ -36,8 +36,13 @@
package org.prismlauncher.utils.logging;
public enum Level {
- LAUNCHER("Launcher"), DEBUG("Debug"), INFO("Info"), MESSAGE("Message"),
- WARNING("Warning"), ERROR("Error", true), FATAL("Fatal", true);
+ LAUNCHER("Launcher"),
+ DEBUG("Debug"),
+ INFO("Info"),
+ MESSAGE("Message"),
+ WARNING("Warning"),
+ ERROR("Error", true),
+ FATAL("Fatal", true);
String name;
boolean stderr;
diff --git a/libraries/launcher/org/prismlauncher/utils/logging/Log.java b/libraries/launcher/org/prismlauncher/utils/logging/Log.java
index e1961991..374a8107 100644
--- a/libraries/launcher/org/prismlauncher/utils/logging/Log.java
+++ b/libraries/launcher/org/prismlauncher/utils/logging/Log.java
@@ -1,6 +1,6 @@
// SPDX-License-Identifier: GPL-3.0-only
/*
- * PolyMC - Minecraft Launcher
+ * Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
*
* This program is free software: you can redistribute it and/or modify
@@ -44,37 +44,12 @@ import java.io.PrintStream;
*/
public final class Log {
- private static final PrintStream ERROR_PREFIX = new PrintStream(System.err) {
- @Override
- public void println(String x) {
- error(x);
- }
-
- @Override
- public void println(Object x) {
- error(String.valueOf(x));
- }
- }, FATAL_PREFIX = new PrintStream(System.err) {
- @Override
- public void println(String x) {
- fatal(x);
- }
-
- @Override
- public void println(Object x) {
- fatal(String.valueOf(x));
- }
- };
-
+ // original before overridden
+ private static final PrintStream OUT = new PrintStream(System.out), ERR = new PrintStream(System.err);
+ private static final PrintStream ERROR_PREFIX = new LogPrintStream(System.err, Level.ERROR),
+ FATAL_PREFIX = new LogPrintStream(System.err, Level.FATAL);
private static final boolean DEBUG = Boolean.getBoolean("org.prismlauncher.debug");
- private Log() {
- }
-
- public static void blankLine() {
- System.out.println();
- }
-
public static void launcher(String message) {
log(message, Level.LAUNCHER);
}
@@ -84,16 +59,9 @@ public final class Log {
}
public static void debug(String message) {
- if (!DEBUG)
- return;
-
log(message, Level.DEBUG);
}
- public static void info(String message) {
- log(message, Level.INFO);
- }
-
public static void warning(String message) {
log(message, Level.WARNING);
}
@@ -113,12 +81,16 @@ public final class Log {
}
/**
- * Logs a message with the prefix !![LEVEL]!.
+ * Logs a message with the prefix <code>!![LEVEL]!</code>. This is picked up by
+ * the log viewer to give it nice colours.
*
* @param message The message
* @param level The level
*/
public static void log(String message, Level level) {
+ if (!DEBUG && level == Level.DEBUG)
+ return;
+
String prefix = "!![" + level.name + "]!";
// prefix first line
message = prefix + message;
@@ -126,9 +98,9 @@ public final class Log {
message = message.replace("\n", "\n" + prefix);
if (level.stderr)
- System.err.println(message);
+ ERR.println(message);
else
- System.out.println(message);
+ OUT.println(message);
}
}
diff --git a/libraries/launcher/org/prismlauncher/utils/logging/LogPrintStream.java b/libraries/launcher/org/prismlauncher/utils/logging/LogPrintStream.java
new file mode 100644
index 00000000..8a182817
--- /dev/null
+++ b/libraries/launcher/org/prismlauncher/utils/logging/LogPrintStream.java
@@ -0,0 +1,99 @@
+// SPDX-License-Identifier: GPL-3.0-only
+/*
+ * Prism Launcher - Minecraft Launcher
+ * Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * Linking this library statically or dynamically with other modules is
+ * making a combined work based on this library. Thus, the terms and
+ * conditions of the GNU General Public License cover the whole
+ * combination.
+ *
+ * As a special exception, the copyright holders of this library give
+ * you permission to link this library with independent modules to
+ * produce an executable, regardless of the license terms of these
+ * independent modules, and to copy and distribute the resulting
+ * executable under terms of your choice, provided that you also meet,
+ * for each linked independent module, the terms and conditions of the
+ * license of that module. An independent module is a module which is
+ * not derived from or based on this library. If you modify this
+ * library, you may extend this exception to your version of the
+ * library, but you are not obliged to do so. If you do not wish to do
+ * so, delete this exception statement from your version.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+package org.prismlauncher.utils.logging;
+
+import java.io.OutputStream;
+import java.io.PrintStream;
+
+/**
+ * Used to create a print stream that redirects to Log.
+ */
+final class LogPrintStream extends PrintStream {
+
+ private final Level level;
+
+ public LogPrintStream(OutputStream out, Level level) {
+ super(out);
+
+ this.level = level;
+ }
+
+ @Override
+ public void println(String x) {
+ Log.log(x, level);
+ }
+
+ @Override
+ public void println(Object x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(boolean x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(char x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(int x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(long x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(float x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(double x) {
+ println(String.valueOf(x));
+ }
+
+ @Override
+ public void println(char[] x) {
+ println(String.valueOf(x));
+ }
+
+} \ No newline at end of file