From d414c887e0c42325cf2e7c778b32e3fb13ee2e69 Mon Sep 17 00:00:00 2001 From: Unknown Date: Sun, 2 Jun 2019 19:41:28 +0800 Subject: 2.9.2 Live Generated Recipe Displays --- src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java') diff --git a/src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java b/src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java index 5b22482e9..f7891670f 100644 --- a/src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java +++ b/src/main/java/me/shedaniel/rei/client/RecipeHelperImpl.java @@ -42,6 +42,7 @@ public class RecipeHelperImpl implements RecipeHelper { private final Map speedCraftAreaSupplierMap = Maps.newHashMap(); private final Map> speedCraftFunctionalMap = Maps.newHashMap(); private final List displayVisibilityHandlers = Lists.newArrayList(); + private final List liveRecipeGenerators = Lists.newArrayList(); private RecipeManager recipeManager; @Override @@ -100,6 +101,8 @@ public class RecipeHelperImpl implements RecipeHelper { if (category.checkTags() ? ItemStack.areEqual(stack, outputStack) : ItemStack.areEqualIgnoreTags(stack, outputStack)) categoriesMap.get(recipeDisplay.getRecipeCategory()).add(recipeDisplay); } + for(LiveRecipeGenerator liveRecipeGenerator : liveRecipeGenerators) + ((Optional) liveRecipeGenerator.getRecipeFor(stack)).ifPresent(o -> categoriesMap.get(liveRecipeGenerator.getCategoryIdentifier()).addAll(o)); Map> recipeCategoryListMap = Maps.newLinkedHashMap(); categories.forEach(category -> { if (categoriesMap.containsKey(category.getIdentifier()) && !categoriesMap.get(category.getIdentifier()).isEmpty()) @@ -141,6 +144,8 @@ public class RecipeHelperImpl implements RecipeHelper { } } } + for(LiveRecipeGenerator liveRecipeGenerator : liveRecipeGenerators) + ((Optional) liveRecipeGenerator.getUsageFor(stack)).ifPresent(o -> categoriesMap.get(liveRecipeGenerator.getCategoryIdentifier()).addAll(o)); Map> recipeCategoryListMap = Maps.newLinkedHashMap(); categories.forEach(category -> { if (categoriesMap.containsKey(category.getIdentifier()) && !categoriesMap.get(category.getIdentifier()).isEmpty()) @@ -198,6 +203,7 @@ public class RecipeHelperImpl implements RecipeHelper { this.speedCraftFunctionalMap.clear(); this.categoryDisplaySettingsMap.clear(); this.displayVisibilityHandlers.clear(); + this.liveRecipeGenerators.clear(); ((DisplayHelperImpl) RoughlyEnoughItemsCore.getDisplayHelper()).resetCache(); BaseBoundsHandler baseBoundsHandler = new BaseBoundsHandlerImpl(); RoughlyEnoughItemsCore.getDisplayHelper().registerBoundsHandler(baseBoundsHandler); @@ -302,4 +308,9 @@ public class RecipeHelperImpl implements RecipeHelper { return categoryDisplaySettingsMap.entrySet().stream().filter(entry -> entry.getKey().equals(category)).map(Map.Entry::getValue).findAny(); } + @Override + public void registerLiveRecipeGenerator(LiveRecipeGenerator liveRecipeGenerator) { + liveRecipeGenerators.add(liveRecipeGenerator); + } + } -- cgit