aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/rei/client/RecipeHelper.java
diff options
context:
space:
mode:
authorUnknown <shekwancheung0528@gmail.com>2019-02-26 16:58:22 +0800
committerUnknown <shekwancheung0528@gmail.com>2019-02-26 16:58:22 +0800
commit398bda6e8051368d48c0737719ce277028dce396 (patch)
treeefbf612ecd5f231b6ce8fd126273a5f49f29c8ca /src/main/java/me/shedaniel/rei/client/RecipeHelper.java
parent9e55b44b710f38c63a4bfd17d0b07318d5c68535 (diff)
downloadRoughlyEnoughItems-398bda6e8051368d48c0737719ce277028dce396.tar.gz
RoughlyEnoughItems-398bda6e8051368d48c0737719ce277028dce396.tar.bz2
RoughlyEnoughItems-398bda6e8051368d48c0737719ce277028dce396.zip
Make dialog remember its location
Diffstat (limited to 'src/main/java/me/shedaniel/rei/client/RecipeHelper.java')
-rw-r--r--src/main/java/me/shedaniel/rei/client/RecipeHelper.java208
1 files changed, 0 insertions, 208 deletions
diff --git a/src/main/java/me/shedaniel/rei/client/RecipeHelper.java b/src/main/java/me/shedaniel/rei/client/RecipeHelper.java
deleted file mode 100644
index 10a3b8cfe..000000000
--- a/src/main/java/me/shedaniel/rei/client/RecipeHelper.java
+++ /dev/null
@@ -1,208 +0,0 @@
-package me.shedaniel.rei.client;
-
-import com.google.common.collect.Lists;
-import com.google.common.collect.Maps;
-import me.shedaniel.rei.RoughlyEnoughItemsCore;
-import me.shedaniel.rei.api.*;
-import net.minecraft.item.ItemStack;
-import net.minecraft.recipe.RecipeManager;
-import net.minecraft.util.Identifier;
-
-import java.awt.*;
-import java.util.*;
-import java.util.List;
-import java.util.concurrent.atomic.AtomicInteger;
-import java.util.stream.Collectors;
-
-public class RecipeHelper implements IRecipeHelper {
-
- private final AtomicInteger recipeCount = new AtomicInteger();
- private final Map<Identifier, List<IRecipeDisplay>> recipeCategoryListMap = Maps.newHashMap();
- private final List<IRecipeCategory> categories = Lists.newArrayList();
- private final Map<Identifier, SpeedCraftAreaSupplier> speedCraftAreaSupplierMap = Maps.newHashMap();
- private final Map<Identifier, List<SpeedCraftFunctional>> speedCraftFunctionalMap = Maps.newHashMap();
- private RecipeManager recipeManager;
-
- @Override
- public List<ItemStack> findCraftableByItems(List<ItemStack> inventoryItems) {
- List<ItemStack> craftables = new ArrayList<>();
- for(List<IRecipeDisplay> value : recipeCategoryListMap.values())
- for(IRecipeDisplay recipeDisplay : value) {
- int slotsCraftable = 0;
- List<List<ItemStack>> requiredInput = (List<List<ItemStack>>) recipeDisplay.getRequiredItems();
- for(List<ItemStack> slot : requiredInput) {
- if (slot.isEmpty()) {
- slotsCraftable++;
- continue;
- }
- boolean slotDone = false;
- for(ItemStack possibleType : inventoryItems) {
- for(ItemStack slotPossible : slot)
- if (ItemStack.areEqualIgnoreTags(slotPossible, possibleType)) {
- slotsCraftable++;
- slotDone = true;
- break;
- }
- if (slotDone)
- break;
- }
- }
- if (slotsCraftable == recipeDisplay.getRequiredItems().size())
- craftables.addAll((List<ItemStack>) recipeDisplay.getOutput());
- }
- return craftables.stream().distinct().collect(Collectors.toList());
- }
-
- @Override
- public void registerCategory(IRecipeCategory category) {
- categories.add(category);
- recipeCategoryListMap.put(category.getIdentifier(), Lists.newLinkedList());
- }
-
- @Override
- public void registerDisplay(Identifier categoryIdentifier, IRecipeDisplay display) {
- if (!recipeCategoryListMap.containsKey(categoryIdentifier))
- return;
- recipeCount.incrementAndGet();
- recipeCategoryListMap.get(categoryIdentifier).add(display);
- }
-
- @Override
- public Map<IRecipeCategory, List<IRecipeDisplay>> getRecipesFor(ItemStack stack) {
- Map<Identifier, List<IRecipeDisplay>> categoriesMap = new HashMap<>();
- categories.forEach(f -> categoriesMap.put(f.getIdentifier(), Lists.newArrayList()));
- for(Map.Entry<Identifier, List<IRecipeDisplay>> entry : recipeCategoryListMap.entrySet()) {
- IRecipeCategory category = getCategory(entry.getKey());
- for(IRecipeDisplay recipeDisplay : entry.getValue())
- for(ItemStack outputStack : (List<ItemStack>) recipeDisplay.getOutput())
- if (category.checkTags() ? ItemStack.areEqual(stack, outputStack) : ItemStack.areEqualIgnoreTags(stack, outputStack))
- categoriesMap.get(recipeDisplay.getRecipeCategory()).add(recipeDisplay);
- }
- Map<IRecipeCategory, List<IRecipeDisplay>> recipeCategoryListMap = Maps.newLinkedHashMap();
- categories.forEach(category -> {
- if (categoriesMap.containsKey(category.getIdentifier()) && !categoriesMap.get(category.getIdentifier()).isEmpty())
- recipeCategoryListMap.put(category, categoriesMap.get(category.getIdentifier()));
- });
- return recipeCategoryListMap;
- }
-
- private IRecipeCategory getCategory(Identifier identifier) {
- return categories.stream().filter(category -> category.getIdentifier().equals(identifier)).findFirst().orElse(null);
- }
-
- @Override
- public RecipeManager getRecipeManager() {
- return recipeManager;
- }
-
- @Override
- public Map<IRecipeCategory, List<IRecipeDisplay>> getUsagesFor(ItemStack stack) {
- Map<Identifier, List<IRecipeDisplay>> categoriesMap = new HashMap<>();
- categories.forEach(f -> categoriesMap.put(f.getIdentifier(), Lists.newArrayList()));
- for(Map.Entry<Identifier, List<IRecipeDisplay>> entry : recipeCategoryListMap.entrySet()) {
- IRecipeCategory category = getCategory(entry.getKey());
- for(IRecipeDisplay recipeDisplay : entry.getValue()) {
- boolean found = false;
- for(List<ItemStack> input : (List<List<ItemStack>>) recipeDisplay.getInput()) {
- for(ItemStack itemStack : input) {
- if (category.checkTags() ? ItemStack.areEqual(itemStack, stack) : ItemStack.areEqualIgnoreTags(itemStack, stack)) {
- categoriesMap.get(recipeDisplay.getRecipeCategory()).add(recipeDisplay);
- found = true;
- break;
- }
- }
- if (found)
- break;
- }
- }
- }
- Map<IRecipeCategory, List<IRecipeDisplay>> recipeCategoryListMap = Maps.newLinkedHashMap();
- categories.forEach(category -> {
- if (categoriesMap.containsKey(category.getIdentifier()) && !categoriesMap.get(category.getIdentifier()).isEmpty())
- recipeCategoryListMap.put(category, categoriesMap.get(category.getIdentifier()));
- });
- return recipeCategoryListMap;
- }
-
- @Override
- public List<IRecipeCategory> getAllCategories() {
- return new LinkedList<>(categories);
- }
-
- @Override
- public Optional<SpeedCraftAreaSupplier> getSpeedCraftButtonArea(IRecipeCategory category) {
- if (!speedCraftAreaSupplierMap.containsKey(category.getIdentifier()))
- return Optional.of(bounds -> new Rectangle((int) bounds.getMaxX() - 16, (int) bounds.getMaxY() - 16, 10, 10));
- return Optional.ofNullable(speedCraftAreaSupplierMap.get(category.getIdentifier()));
- }
-
- @Override
- public void registerSpeedCraftButtonArea(Identifier category, SpeedCraftAreaSupplier rectangle) {
- speedCraftAreaSupplierMap.put(category, rectangle);
- }
-
- @Override
- public List<SpeedCraftFunctional> getSpeedCraftFunctional(IRecipeCategory category) {
- if (speedCraftFunctionalMap.get(category.getIdentifier()) == null)
- return Lists.newArrayList();
- return speedCraftFunctionalMap.get(category.getIdentifier());
- }
-
- @Override
- public void registerSpeedCraftFunctional(Identifier category, SpeedCraftFunctional functional) {
- List<SpeedCraftFunctional> list = speedCraftFunctionalMap.containsKey(category) ? new LinkedList<>(speedCraftFunctionalMap.get(category)) : Lists.newLinkedList();
- list.add(functional);
- speedCraftFunctionalMap.put(category, list);
- }
-
- @SuppressWarnings("deprecation")
- public void recipesLoaded(RecipeManager recipeManager) {
- this.recipeCount.set(0);
- this.recipeManager = recipeManager;
- this.recipeCategoryListMap.clear();
- this.categories.clear();
- this.speedCraftAreaSupplierMap.clear();
- this.speedCraftFunctionalMap.clear();
- List<IRecipePlugin> plugins = new LinkedList<>(RoughlyEnoughItemsCore.getPlugins());
- plugins.sort((first, second) -> {
- return second.getPriority() - first.getPriority();
- });
- RoughlyEnoughItemsCore.LOGGER.info("Loading %d REI plugins: %s", plugins.size(), String.join(", ", plugins.stream().map(plugin -> {
- return RoughlyEnoughItemsCore.getPluginIdentifier(plugin).map(Identifier::toString).orElseGet(() -> "null");
- }).collect(Collectors.toList())));
- Collections.reverse(plugins);
- RoughlyEnoughItemsCore.getItemRegisterer().getModifiableItemList().clear();
- IPluginDisabler pluginDisabler = RoughlyEnoughItemsCore.getPluginDisabler();
- plugins.forEach(plugin -> {
- Identifier identifier = RoughlyEnoughItemsCore.getPluginIdentifier(plugin).orElseGet(() -> new Identifier("null"));
- if (pluginDisabler.isFunctionEnabled(identifier, PluginFunction.REGISTER_ITEMS))
- plugin.registerItems(RoughlyEnoughItemsCore.getItemRegisterer());
- if (pluginDisabler.isFunctionEnabled(identifier, PluginFunction.REGISTER_CATEGORIES))
- plugin.registerPluginCategories(this);
- if (pluginDisabler.isFunctionEnabled(identifier, PluginFunction.REGISTER_RECIPE_DISPLAYS))
- plugin.registerRecipeDisplays(this);
- if (pluginDisabler.isFunctionEnabled(identifier, PluginFunction.REGISTER_SPEED_CRAFT))
- plugin.registerSpeedCraft(this);
- });
- RoughlyEnoughItemsCore.LOGGER.info("Registered REI Categories: " + String.join(", ", categories.stream().map(IRecipeCategory::getCategoryName).collect(Collectors.toList())));
- RoughlyEnoughItemsCore.LOGGER.info("Registered %d recipes for REI.", recipeCount.get());
- }
-
- @Override
- public int getRecipeCount() {
- return recipeCount.get();
- }
-
- @Override
- public Map<IRecipeCategory, List<IRecipeDisplay>> getAllRecipes() {
- Map<IRecipeCategory, List<IRecipeDisplay>> map = Maps.newLinkedHashMap();
- Map<Identifier, List<IRecipeDisplay>> tempMap = Maps.newLinkedHashMap();
- recipeCategoryListMap.forEach((identifier, recipeDisplays) -> tempMap.put(identifier, new LinkedList<>(recipeDisplays)));
- categories.forEach(category -> {
- if (tempMap.containsKey(category.getIdentifier()))
- map.put(category, tempMap.get(category.getIdentifier()));
- });
- return map;
- }
-
-}