Fixed error detection login in ModelLoader, reduced the maximum number of printed stack traces to 5 per domain.
This commit is contained in:
parent
447a87c0c7
commit
17e8de8a3a
1 changed files with 54 additions and 11 deletions
|
@ -81,7 +81,7 @@ public class ModelLoader extends ModelBakery
|
||||||
private final Set<ResourceLocation> textures = Sets.newHashSet();
|
private final Set<ResourceLocation> textures = Sets.newHashSet();
|
||||||
private final Set<ResourceLocation> loadingModels = Sets.newHashSet();
|
private final Set<ResourceLocation> loadingModels = Sets.newHashSet();
|
||||||
private final Set<ModelResourceLocation> missingVariants = Sets.newHashSet();
|
private final Set<ModelResourceLocation> missingVariants = Sets.newHashSet();
|
||||||
private final Map<ModelResourceLocation, Exception> loadingExceptions = Maps.newHashMap();
|
private final Map<ResourceLocation, Exception> loadingExceptions = Maps.newHashMap();
|
||||||
private IModel missingModel = null;
|
private IModel missingModel = null;
|
||||||
private IModel itemModel = new ItemLayerModel(MODEL_GENERATED);
|
private IModel itemModel = new ItemLayerModel(MODEL_GENERATED);
|
||||||
|
|
||||||
|
@ -198,11 +198,25 @@ public class ModelLoader extends ModelBakery
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void storeException(ModelResourceLocation location, Exception exception)
|
private void storeException(ResourceLocation location, Exception exception)
|
||||||
{
|
{
|
||||||
loadingExceptions.put(location, exception);
|
loadingExceptions.put(location, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ModelBlockDefinition getModelBlockDefinition(ResourceLocation location)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return super.getModelBlockDefinition(location);
|
||||||
|
}
|
||||||
|
catch (Exception exception)
|
||||||
|
{
|
||||||
|
storeException(location, new Exception("Could not load model definition for variant " + location, exception));
|
||||||
|
}
|
||||||
|
return new ModelBlockDefinition(new ArrayList<ModelBlockDefinition>());
|
||||||
|
}
|
||||||
|
|
||||||
private void loadItems()
|
private void loadItems()
|
||||||
{
|
{
|
||||||
registerVariantNames();
|
registerVariantNames();
|
||||||
|
@ -864,30 +878,59 @@ public class ModelLoader extends ModelBakery
|
||||||
public void onPostBakeEvent(IRegistry<ModelResourceLocation, IBakedModel> modelRegistry)
|
public void onPostBakeEvent(IRegistry<ModelResourceLocation, IBakedModel> modelRegistry)
|
||||||
{
|
{
|
||||||
IBakedModel missingModel = modelRegistry.getObject(MODEL_MISSING);
|
IBakedModel missingModel = modelRegistry.getObject(MODEL_MISSING);
|
||||||
for(Map.Entry<ModelResourceLocation, Exception> entry : loadingExceptions.entrySet())
|
Map<String, Integer> modelErrors = Maps.newHashMap();
|
||||||
|
for(Map.Entry<ResourceLocation, Exception> entry : loadingExceptions.entrySet())
|
||||||
{
|
{
|
||||||
IBakedModel model = modelRegistry.getObject(entry.getKey());
|
// ignoring pure ResourceLocation arguments, all things we care about pass ModelResourceLocation
|
||||||
|
if(entry.getKey() instanceof ModelResourceLocation)
|
||||||
|
{
|
||||||
|
ModelResourceLocation location = (ModelResourceLocation)entry.getKey();
|
||||||
|
IBakedModel model = modelRegistry.getObject(location);
|
||||||
if(model == null || model == missingModel)
|
if(model == null || model == missingModel)
|
||||||
|
{
|
||||||
|
String domain = entry.getKey().getResourceDomain();
|
||||||
|
Integer errorCountBox = modelErrors.get(domain);
|
||||||
|
int errorCount = errorCountBox == null ? 0 : errorCountBox;
|
||||||
|
errorCount++;
|
||||||
|
if(errorCount < 5)
|
||||||
{
|
{
|
||||||
FMLLog.getLogger().error("Exception loading model for variant " + entry.getKey(), entry.getValue());
|
FMLLog.getLogger().error("Exception loading model for variant " + entry.getKey(), entry.getValue());
|
||||||
}
|
}
|
||||||
|
modelErrors.put(domain, errorCount);
|
||||||
|
}
|
||||||
if(model == null)
|
if(model == null)
|
||||||
{
|
{
|
||||||
modelRegistry.putObject(entry.getKey(), missingModel);
|
modelRegistry.putObject(location, missingModel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(ModelResourceLocation missing : missingVariants)
|
for(ModelResourceLocation missing : missingVariants)
|
||||||
{
|
{
|
||||||
IBakedModel model = modelRegistry.getObject(missing);
|
IBakedModel model = modelRegistry.getObject(missing);
|
||||||
if(model == null || model == missingModel)
|
if(model == null || model == missingModel)
|
||||||
|
{
|
||||||
|
String domain = missing.getResourceDomain();
|
||||||
|
Integer errorCountBox = modelErrors.get(domain);
|
||||||
|
int errorCount = errorCountBox == null ? 0 : errorCountBox;
|
||||||
|
errorCount++;
|
||||||
|
if(errorCount < 5)
|
||||||
{
|
{
|
||||||
FMLLog.severe("Model definition for location %s not found", missing);
|
FMLLog.severe("Model definition for location %s not found", missing);
|
||||||
}
|
}
|
||||||
|
modelErrors.put(domain, errorCount);
|
||||||
|
}
|
||||||
if(model == null)
|
if(model == null)
|
||||||
{
|
{
|
||||||
modelRegistry.putObject(missing, missingModel);
|
modelRegistry.putObject(missing, missingModel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for(Map.Entry<String, Integer> e : modelErrors.entrySet())
|
||||||
|
{
|
||||||
|
if(e.getValue() >= 5)
|
||||||
|
{
|
||||||
|
FMLLog.severe("Supressed additional %s model loading errors for domain %s", e.getValue(), e.getKey());
|
||||||
|
}
|
||||||
|
}
|
||||||
isLoading = false;
|
isLoading = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue