Improve error message from crashes during loading (#3362)

This commit is contained in:
mezz 2016-11-10 18:00:11 -08:00 committed by cpw
parent 998a78c3c1
commit 7a4aa5a1c4
3 changed files with 57 additions and 10 deletions

View file

@ -23,6 +23,7 @@ import java.lang.reflect.InvocationTargetException;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
import net.minecraftforge.fml.common.LoaderState.ModState; import net.minecraftforge.fml.common.LoaderState.ModState;
@ -62,6 +63,7 @@ public class LoadController
private LoaderState state; private LoaderState state;
private Multimap<String, ModState> modStates = ArrayListMultimap.create(); private Multimap<String, ModState> modStates = ArrayListMultimap.create();
private Multimap<String, Throwable> errors = ArrayListMultimap.create(); private Multimap<String, Throwable> errors = ArrayListMultimap.create();
private Map<String, String> modNames = Maps.newHashMap();
private List<ModContainer> activeModList = Lists.newArrayList(); private List<ModContainer> activeModList = Lists.newArrayList();
private ModContainer activeContainer; private ModContainer activeContainer;
private BiMap<ModContainer, Object> modObjectList; private BiMap<ModContainer, Object> modObjectList;
@ -130,6 +132,7 @@ public class LoadController
modStates.put(mod.getModId(), ModState.UNLOADED); modStates.put(mod.getModId(), ModState.UNLOADED);
modStates.put(mod.getModId(), ModState.DISABLED); modStates.put(mod.getModId(), ModState.DISABLED);
} }
modNames.put(mod.getModId(), mod.getName());
} }
eventChannels = eventBus.build(); eventChannels = eventBus.build();
@ -149,7 +152,7 @@ public class LoadController
state = state.transition(!errors.isEmpty()); state = state.transition(!errors.isEmpty());
if (state != desiredState && !forceState) if (state != desiredState && !forceState)
{ {
Throwable toThrow = null; Entry<String, Throwable> toThrow = null;
FMLLog.severe("Fatal errors were detected during the transition from %s to %s. Loading cannot continue", oldState, desiredState); FMLLog.severe("Fatal errors were detected during the transition from %s to %s. Loading cannot continue", oldState, desiredState);
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
printModStates(sb); printModStates(sb);
@ -159,14 +162,16 @@ public class LoadController
FMLLog.severe("The following problems were captured during this phase"); FMLLog.severe("The following problems were captured during this phase");
for (Entry<String, Throwable> error : errors.entries()) for (Entry<String, Throwable> error : errors.entries())
{ {
FMLLog.log(Level.ERROR, error.getValue(), "Caught exception from %s", error.getKey()); String modId = error.getKey();
String modName = modNames.get(modId);
FMLLog.log(Level.ERROR, error.getValue(), "Caught exception from %s (%s)", modName, modId);
if (error.getValue() instanceof IFMLHandledException) if (error.getValue() instanceof IFMLHandledException)
{ {
toThrow = error.getValue(); toThrow = error;
} }
else if (toThrow == null) else if (toThrow == null)
{ {
toThrow = error.getValue(); toThrow = error;
} }
} }
} }
@ -177,13 +182,12 @@ public class LoadController
"ForgeModLoader, especially Optifine, to see if there are fixes available."); "ForgeModLoader, especially Optifine, to see if there are fixes available.");
throw new RuntimeException("The ForgeModLoader state engine is invalid"); throw new RuntimeException("The ForgeModLoader state engine is invalid");
} }
if (toThrow != null && toThrow instanceof RuntimeException) if (toThrow != null)
{ {
throw (RuntimeException)toThrow; String modId = toThrow.getKey();
} String modName = modNames.get(modId);
else String errMsg = String.format("Caught exception from %s (%s)", modName, modId);
{ throw new LoaderExceptionModCrash(errMsg, toThrow.getValue());
throw new LoaderException(toThrow);
} }
} }
else if (state != desiredState && forceState) else if (state != desiredState && forceState)

View file

@ -38,6 +38,10 @@ public class LoaderException extends EnhancedRuntimeException
{ {
super(message); super(message);
} }
public LoaderException(String message, Throwable cause)
{
super(message, cause);
}
@Override protected void printStackTrace(WrappedPrintStream stream){} @Override protected void printStackTrace(WrappedPrintStream stream){}
} }

View file

@ -0,0 +1,39 @@
/*
* Minecraft Forge
* Copyright (c) 2016.
*
* 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.common;
/**
* Prevent LoaderException from adding its own stack trace to the wrapped throwable's stack trace.
*/
public class LoaderExceptionModCrash extends LoaderException
{
private static final long serialVersionUID = 1L;
public LoaderExceptionModCrash(String message, Throwable cause)
{
super(message, cause);
}
@Override
public synchronized Throwable fillInStackTrace()
{
return this;
}
}