103 lines
4.3 KiB
Java
103 lines
4.3 KiB
Java
/*
|
|
* Minecraft Forge
|
|
* Copyright (c) 2016-2018.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation version 2.1
|
|
* of the License.
|
|
*
|
|
* This library 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
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
package net.minecraftforge.fml;
|
|
|
|
import com.google.common.base.Strings;
|
|
import com.google.common.collect.ObjectArrays;
|
|
import cpw.mods.modlauncher.Launcher;
|
|
import org.apache.logging.log4j.Level;
|
|
import org.apache.logging.log4j.core.Filter;
|
|
import org.apache.logging.log4j.core.LoggerContext;
|
|
import org.apache.logging.log4j.core.config.Configurator;
|
|
import org.apache.logging.log4j.core.filter.MarkerFilter;
|
|
|
|
import java.io.File;
|
|
import java.lang.reflect.Field;
|
|
import java.util.Objects;
|
|
|
|
public class LaunchTesting
|
|
{
|
|
public static void main(String... args) throws InterruptedException
|
|
{
|
|
Configurator.setRootLevel(Level.DEBUG);
|
|
final MarkerFilter classloadingFilter = MarkerFilter.createFilter("CLASSLOADING", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
final MarkerFilter launchpluginFilter = MarkerFilter.createFilter("LAUNCHPLUGIN", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
final MarkerFilter axformFilter= MarkerFilter.createFilter("AXFORM", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
final MarkerFilter eventbusFilter = MarkerFilter.createFilter("EVENTBUS", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
final MarkerFilter distxformFilter = MarkerFilter.createFilter("DISTXFORM", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
final LoggerContext logcontext = LoggerContext.getContext(false);
|
|
logcontext.getConfiguration().addFilter(classloadingFilter);
|
|
logcontext.getConfiguration().addFilter(launchpluginFilter);
|
|
logcontext.getConfiguration().addFilter(axformFilter);
|
|
logcontext.getConfiguration().addFilter(eventbusFilter);
|
|
logcontext.getConfiguration().addFilter(distxformFilter);
|
|
logcontext.updateLoggers();
|
|
File invsorter = new File("/home/cpw/projects/minecraft/inventorysorter/classes");
|
|
if (invsorter.exists()) {
|
|
System.setProperty("fml.explodedDir", "/home/cpw/projects/minecraft/inventorysorter/classes"); //TODO: Move this to a example included in our tests, not a random location...
|
|
}
|
|
String assets = System.getenv().getOrDefault("assetDirectory", "assets");
|
|
String target = System.getenv().get("target");
|
|
|
|
if (target == null) {
|
|
throw new IllegalArgumentException("Environment variable target must be set.");
|
|
}
|
|
|
|
if (Objects.equals(target,"fmldevclient")) {
|
|
hackNatives();
|
|
Launcher.main("--launchTarget", target,
|
|
"--gameDir", ".",
|
|
"--accessToken", "blah",
|
|
"--version", "FMLDev",
|
|
"--assetIndex", "1.13",
|
|
"--assetsDir", assets,
|
|
"--userProperties", "{}");
|
|
} else if (Objects.equals(target, "fmldevserver")) {
|
|
String[] launchargs = ObjectArrays.concat(new String[] {"--launchTarget", target,
|
|
"--gameDir", "."}, args, String.class);
|
|
Launcher.main(launchargs);
|
|
}
|
|
Thread.sleep(10000);
|
|
}
|
|
|
|
private static void hackNatives()
|
|
{
|
|
String paths = System.getProperty("java.library.path");
|
|
String nativesDir = System.getenv().get("nativesDirectory");
|
|
|
|
if (Strings.isNullOrEmpty(paths))
|
|
paths = nativesDir;
|
|
else
|
|
paths += File.pathSeparator + nativesDir;
|
|
|
|
System.setProperty("java.library.path", paths);
|
|
|
|
// hack the classloader now.
|
|
try
|
|
{
|
|
final Field sysPathsField = ClassLoader.class.getDeclaredField("sys_paths");
|
|
sysPathsField.setAccessible(true);
|
|
sysPathsField.set(null, null);
|
|
}
|
|
catch(Throwable t) {}
|
|
}
|
|
|
|
}
|