summaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
authorWyvest <45589059+Wyvest@users.noreply.github.com>2022-06-11 18:16:53 +0700
committerWyvest <45589059+Wyvest@users.noreply.github.com>2022-06-11 18:16:53 +0700
commitf28882eb8fc6886034c823fc688ef0775cd3bafa (patch)
treec42b7d1b6b52561a07db05f7b0cd19e56e4c781a /src/main
parent6b324f093b1483e3d647667950e3bd5e4df9a3b7 (diff)
downloadOneConfigLoader-f28882eb8fc6886034c823fc688ef0775cd3bafa.tar.gz
OneConfigLoader-f28882eb8fc6886034c823fc688ef0775cd3bafa.tar.bz2
OneConfigLoader-f28882eb8fc6886034c823fc688ef0775cd3bafa.zip
yes
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java43
1 files changed, 36 insertions, 7 deletions
diff --git a/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java b/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java
index 4d03236..f7cae69 100644
--- a/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java
+++ b/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java
@@ -8,6 +8,7 @@ import net.minecraftforge.fml.relauncher.IFMLLoadingPlugin;
import javax.net.ssl.HttpsURLConnection;
import java.io.*;
+import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.net.MalformedURLException;
import java.net.URL;
@@ -23,7 +24,8 @@ import java.util.Map;
public class OneConfigLoader implements IFMLLoadingPlugin {
- private IFMLLoadingPlugin OneConfigTransformer = null;
+ private final Object transformer;
+ private final Class<?> clazz;
public OneConfigLoader() {
File oneConfigDir = new File(Launch.minecraftHome, "OneConfig");
@@ -78,7 +80,8 @@ public class OneConfigLoader implements IFMLLoadingPlugin {
addToClasspath(oneConfigFile);
}
try {
- OneConfigTransformer = ((IFMLLoadingPlugin) Launch.classLoader.findClass("cc.polyfrost.oneconfig.internal.plugin.LoadingPlugin").newInstance());
+ clazz = Launch.classLoader.findClass("cc.polyfrost.oneconfig.internal.plugin.LoadingPlugin");
+ transformer = clazz.newInstance();
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException e) {
throw new RuntimeException(e);
}
@@ -168,26 +171,52 @@ public class OneConfigLoader implements IFMLLoadingPlugin {
@Override
public String[] getASMTransformerClass() {
- return OneConfigTransformer == null ? null : OneConfigTransformer.getASMTransformerClass();
+ try {
+ return transformer == null ? new String[]{} : (String[]) clazz.getDeclaredMethod("getASMTransformerClass").invoke(transformer);
+ } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
+ e.printStackTrace();
+ }
+ return new String[]{};
}
@Override
public String getModContainerClass() {
- return OneConfigTransformer == null ? null : OneConfigTransformer.getModContainerClass();
+ try {
+ return transformer == null ? null : (String) clazz.getDeclaredMethod("getModContainerClass").invoke(transformer);
+ } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
+ e.printStackTrace();
+ }
+ return null;
}
@Override
public String getSetupClass() {
- return OneConfigTransformer == null ? null : OneConfigTransformer.getSetupClass();
+ try {
+ return transformer == null ? null : (String) clazz.getDeclaredMethod("getSetupClass").invoke(transformer);
+ } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
+ e.printStackTrace();
+ }
+ return null;
}
@Override
public void injectData(Map<String, Object> data) {
- if (OneConfigTransformer != null) OneConfigTransformer.injectData(data);
+ try {
+ if (transformer != null) {
+ clazz.getDeclaredMethod("injectData").invoke(transformer, data);
+ }
+ } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
+ e.printStackTrace();
+ }
}
@Override
public String getAccessTransformerClass() {
- return OneConfigTransformer == null ? null : OneConfigTransformer.getAccessTransformerClass();
+ try {
+ return transformer == null ? null : (String) clazz.getDeclaredMethod("getAccessTransformerClass").invoke(transformer);
+ } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
+ e.printStackTrace();
+ }
+ return null;
}
}