package net.minecraft.client.resources.model; import com.google.gson.JsonParser; import com.mojang.logging.LogUtils; import com.mojang.serialization.JsonOps; import com.mojang.serialization.DataResult.Error; import java.io.Reader; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.CompletableFuture; import java.util.concurrent.Executor; import javax.annotation.Nullable; import net.minecraft.Util; import net.minecraft.client.renderer.item.ClientItem; import net.minecraft.resources.FileToIdConverter; import net.minecraft.resources.ResourceLocation; import net.minecraft.server.packs.resources.Resource; import net.minecraft.server.packs.resources.ResourceManager; import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.api.distmarker.OnlyIn; import org.slf4j.Logger; @OnlyIn(Dist.CLIENT) public class ClientItemInfoLoader { private static final Logger LOGGER = LogUtils.getLogger(); private static final FileToIdConverter LISTER = FileToIdConverter.json("items"); public static CompletableFuture scheduleLoad(ResourceManager p_377664_, Executor p_378750_) { return CompletableFuture.>supplyAsync(() -> LISTER.listMatchingResources(p_377664_), p_378750_) .thenCompose( p_377544_ -> { List> list = new ArrayList<>(p_377544_.size()); p_377544_.forEach( (p_378387_, p_375808_) -> list.add( CompletableFuture.supplyAsync( () -> { ResourceLocation resourcelocation = LISTER.fileToId(p_378387_); try { ClientItemInfoLoader.PendingLoad clientiteminfoloader$pendingload; try (Reader reader = p_375808_.openAsReader()) { ClientItem clientitem = ClientItem.CODEC .parse(JsonOps.INSTANCE, JsonParser.parseReader(reader)) .ifError( p_376861_ -> LOGGER.error( "Couldn't parse item model '{}' from pack '{}': {}", resourcelocation, p_375808_.sourcePackId(), p_376861_.message() ) ) .result() .orElse(null); clientiteminfoloader$pendingload = new ClientItemInfoLoader.PendingLoad(resourcelocation, clientitem); } return clientiteminfoloader$pendingload; } catch (Exception exception) { LOGGER.error("Failed to open item model {} from pack '{}'", p_378387_, p_375808_.sourcePackId(), exception); return new ClientItemInfoLoader.PendingLoad(resourcelocation, null); } }, p_378750_ ) ) ); return Util.sequence(list).thenApply(p_376092_ -> { Map map = new HashMap<>(); for (ClientItemInfoLoader.PendingLoad clientiteminfoloader$pendingload : p_376092_) { if (clientiteminfoloader$pendingload.clientItemInfo != null) { map.put(clientiteminfoloader$pendingload.id, clientiteminfoloader$pendingload.clientItemInfo); } } return new ClientItemInfoLoader.LoadedClientInfos(map); }); } ); } @OnlyIn(Dist.CLIENT) public static record LoadedClientInfos(Map contents) { } @OnlyIn(Dist.CLIENT) static record PendingLoad(ResourceLocation id, @Nullable ClientItem clientItemInfo) { } }