2013-03-08 00:25:48 +00:00
|
|
|
/*
|
2016-06-23 03:49:47 +00:00
|
|
|
* Minecraft Forge
|
2018-03-25 15:59:43 +00:00
|
|
|
* Copyright (c) 2018.
|
2016-06-23 03:49:47 +00:00
|
|
|
*
|
|
|
|
* 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
|
2013-03-08 00:25:48 +00:00
|
|
|
*/
|
|
|
|
|
2018-03-25 15:59:43 +00:00
|
|
|
package net.minecraftforge.fml;
|
2012-07-22 14:26:38 +00:00
|
|
|
|
2018-04-07 22:15:32 +00:00
|
|
|
import com.google.common.base.Strings;
|
2018-03-25 15:59:43 +00:00
|
|
|
import cpw.mods.modlauncher.Launcher;
|
|
|
|
import org.apache.logging.log4j.Level;
|
2018-06-06 15:37:56 +00:00
|
|
|
import org.apache.logging.log4j.core.Filter;
|
|
|
|
import org.apache.logging.log4j.core.LoggerContext;
|
2018-03-25 15:59:43 +00:00
|
|
|
import org.apache.logging.log4j.core.config.Configurator;
|
2018-06-06 15:37:56 +00:00
|
|
|
import org.apache.logging.log4j.core.filter.MarkerFilter;
|
2012-07-22 14:26:38 +00:00
|
|
|
|
2018-04-07 22:15:32 +00:00
|
|
|
import java.io.File;
|
|
|
|
import java.lang.reflect.Field;
|
|
|
|
|
2018-03-25 15:59:43 +00:00
|
|
|
public class LaunchTesting
|
2012-07-22 14:26:38 +00:00
|
|
|
{
|
2018-04-07 15:48:43 +00:00
|
|
|
public static void main(String... args) throws InterruptedException
|
2012-07-22 14:26:38 +00:00
|
|
|
{
|
2018-03-25 15:59:43 +00:00
|
|
|
Configurator.setRootLevel(Level.DEBUG);
|
2018-06-06 15:37:56 +00:00
|
|
|
final MarkerFilter classloadingFilter = MarkerFilter.createFilter("CLASSLOADING", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
|
|
final MarkerFilter launchpluginFilter = MarkerFilter.createFilter("LAUNCHPLUGIN", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
2018-06-11 01:12:46 +00:00
|
|
|
final MarkerFilter axformFilter= MarkerFilter.createFilter("AXFORM", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
|
|
|
final MarkerFilter eventbusFilter = MarkerFilter.createFilter("EVENTBUS", Filter.Result.DENY, Filter.Result.NEUTRAL);
|
2018-06-06 15:37:56 +00:00
|
|
|
final LoggerContext logcontext = LoggerContext.getContext(false);
|
2018-06-11 01:12:46 +00:00
|
|
|
logcontext.getConfiguration().addFilter(classloadingFilter);
|
2018-06-06 15:37:56 +00:00
|
|
|
logcontext.getConfiguration().addFilter(launchpluginFilter);
|
2018-06-11 01:12:46 +00:00
|
|
|
logcontext.getConfiguration().addFilter(axformFilter);
|
|
|
|
logcontext.getConfiguration().addFilter(eventbusFilter);
|
2018-06-06 15:37:56 +00:00
|
|
|
logcontext.updateLoggers();
|
2018-06-15 19:03:35 +00:00
|
|
|
System.setProperty("fml.explodedDir", "/home/cpw/projects/mods/inventorysorter/classes");
|
2018-04-07 22:15:32 +00:00
|
|
|
hackNatives();
|
2018-06-23 02:45:01 +00:00
|
|
|
Launcher.main("--launchTarget", System.getProperty("target"),"--gameDir", ".",
|
2018-06-06 15:37:56 +00:00
|
|
|
"--accessToken", "blah", "--version", "FMLDev", "--assetIndex", "1.12",
|
|
|
|
"--assetsDir","/home/cpw/.gradle/caches/minecraft/assets",
|
|
|
|
"--userProperties", "{}");
|
2018-04-07 15:48:43 +00:00
|
|
|
Thread.sleep(10000);
|
2012-07-22 14:26:38 +00:00
|
|
|
}
|
2018-04-07 22:15:32 +00:00
|
|
|
|
|
|
|
private static void hackNatives()
|
|
|
|
{
|
|
|
|
String paths = System.getProperty("java.library.path");
|
|
|
|
String nativesDir = "/home/cpw/.gradle/caches/minecraft/net/minecraft/natives/1.12.2";
|
|
|
|
|
|
|
|
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) {}
|
|
|
|
}
|
|
|
|
|
2012-07-22 14:26:38 +00:00
|
|
|
}
|