Fixed missing variant logging; added the possibility to specify the item variant in the blockstate json.
This commit is contained in:
parent
897d41fa77
commit
685a97fd93
1 changed files with 16 additions and 4 deletions
|
@ -91,7 +91,8 @@ public class ModelLoader extends ModelBakery
|
||||||
isLoading = true;
|
isLoading = true;
|
||||||
loadBlocks();
|
loadBlocks();
|
||||||
loadItems();
|
loadItems();
|
||||||
stateModels.put(MODEL_MISSING, getModel(new ResourceLocation(MODEL_MISSING.getResourceDomain(), MODEL_MISSING.getResourcePath())));
|
IModel missing = getModel(new ResourceLocation(MODEL_MISSING.getResourceDomain(), MODEL_MISSING.getResourcePath()));
|
||||||
|
stateModels.put(MODEL_MISSING, missing);
|
||||||
textures.remove(TextureMap.LOCATION_MISSING_TEXTURE);
|
textures.remove(TextureMap.LOCATION_MISSING_TEXTURE);
|
||||||
textures.addAll(LOCATIONS_BUILTIN_TEXTURES);
|
textures.addAll(LOCATIONS_BUILTIN_TEXTURES);
|
||||||
textureMap.loadSprites(resourceManager, new IIconCreator()
|
textureMap.loadSprites(resourceManager, new IIconCreator()
|
||||||
|
@ -106,9 +107,17 @@ public class ModelLoader extends ModelBakery
|
||||||
});
|
});
|
||||||
sprites.put(new ResourceLocation("missingno"), textureMap.getMissingSprite());
|
sprites.put(new ResourceLocation("missingno"), textureMap.getMissingSprite());
|
||||||
Function<ResourceLocation, TextureAtlasSprite> textureGetter = Functions.forMap(sprites, textureMap.getMissingSprite());
|
Function<ResourceLocation, TextureAtlasSprite> textureGetter = Functions.forMap(sprites, textureMap.getMissingSprite());
|
||||||
|
IFlexibleBakedModel missingBaked = missing.bake(missing.getDefaultState(), Attributes.DEFAULT_BAKED_FORMAT, textureGetter);
|
||||||
for(Entry<ModelResourceLocation, IModel> e : stateModels.entrySet())
|
for(Entry<ModelResourceLocation, IModel> e : stateModels.entrySet())
|
||||||
{
|
{
|
||||||
bakedRegistry.putObject(e.getKey(), e.getValue().bake(e.getValue().getDefaultState(), Attributes.DEFAULT_BAKED_FORMAT, textureGetter));
|
if(e.getValue() == getMissingModel())
|
||||||
|
{
|
||||||
|
bakedRegistry.putObject(e.getKey(), missingBaked);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
bakedRegistry.putObject(e.getKey(), e.getValue().bake(e.getValue().getDefaultState(), Attributes.DEFAULT_BAKED_FORMAT, textureGetter));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return bakedRegistry;
|
return bakedRegistry;
|
||||||
}
|
}
|
||||||
|
@ -159,7 +168,8 @@ public class ModelLoader extends ModelBakery
|
||||||
IModel model = getModel(file);
|
IModel model = getModel(file);
|
||||||
if(model == null || model == getMissingModel())
|
if(model == null || model == getMissingModel())
|
||||||
{
|
{
|
||||||
missingVariants.add(memory);
|
FMLLog.fine("Item json isn't found for '" + memory + "', trying to load the variant from the blockstate json");
|
||||||
|
registerVariant(getModelBlockDefinition(memory), memory);
|
||||||
}
|
}
|
||||||
else stateModels.put(memory, model);
|
else stateModels.put(memory, model);
|
||||||
}
|
}
|
||||||
|
@ -569,9 +579,11 @@ public class ModelLoader extends ModelBakery
|
||||||
|
|
||||||
public void onPostBakeEvent(IRegistry modelRegistry)
|
public void onPostBakeEvent(IRegistry modelRegistry)
|
||||||
{
|
{
|
||||||
|
Object missingModel = modelRegistry.getObject(MODEL_MISSING);
|
||||||
for(ModelResourceLocation missing : missingVariants)
|
for(ModelResourceLocation missing : missingVariants)
|
||||||
{
|
{
|
||||||
if(modelRegistry.getObject(missing) == null)
|
Object model = modelRegistry.getObject(missing);
|
||||||
|
if(model == null || model == missingModel)
|
||||||
{
|
{
|
||||||
FMLLog.severe("Model definition for location %s not found", missing);
|
FMLLog.severe("Model definition for location %s not found", missing);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue