ContainerInfoHandler.java 1.5 KB

1234567891011121314151617181920212223242526272829303132333435
  1. /*
  2. * Roughly Enough Items by Danielshe.
  3. * Licensed under the MIT License.
  4. */
  5. package me.shedaniel.rei.server;
  6. import com.google.common.collect.Maps;
  7. import net.minecraft.container.Container;
  8. import net.minecraft.util.Identifier;
  9. import java.util.Map;
  10. public class ContainerInfoHandler {
  11. private static final Map<String, Map<Class<? extends Container>, ContainerInfo>> containerInfoMap = Maps.newLinkedHashMap();
  12. public static void registerContainerInfo(Identifier category, ContainerInfo containerInfo) {
  13. if (!containerInfoMap.containsKey(category.toString()))
  14. containerInfoMap.put(category.toString(), Maps.newLinkedHashMap());
  15. containerInfoMap.get(category.toString()).put(containerInfo.getContainerClass(), containerInfo);
  16. }
  17. public static boolean isCategoryHandled(Identifier category) {
  18. return containerInfoMap.containsKey(category.toString()) && !containerInfoMap.get(category.toString()).isEmpty();
  19. }
  20. public static ContainerInfo getContainerInfo(Identifier category, Class<?> containerClass) {
  21. if (!isCategoryHandled(category)) return null;
  22. Map<Class<? extends Container>, ContainerInfo> infoMap = containerInfoMap.get(category.toString());
  23. if (infoMap.containsKey(containerClass)) return infoMap.get(containerClass);
  24. for (Map.Entry<Class<? extends Container>, ContainerInfo> entry : infoMap.entrySet())
  25. if (entry.getKey().isAssignableFrom(containerClass)) return entry.getValue();
  26. return null;
  27. }
  28. }