diff options
| author | shedaniel <daniel@shedaniel.me> | 2021-08-03 18:29:21 +0800 |
|---|---|---|
| committer | shedaniel <daniel@shedaniel.me> | 2021-08-03 18:29:21 +0800 |
| commit | 606ebaf9145b32f63cdeb330f16496df6a68ec2f (patch) | |
| tree | d7e9d91a8a3b3913a368af74cc1d5077727909e1 /runtime/src/main/java/me | |
| parent | b866becfb620c02a74fb990915001e154b5d2b0b (diff) | |
| download | RoughlyEnoughItems-606ebaf9145b32f63cdeb330f16496df6a68ec2f.tar.gz RoughlyEnoughItems-606ebaf9145b32f63cdeb330f16496df6a68ec2f.tar.bz2 RoughlyEnoughItems-606ebaf9145b32f63cdeb330f16496df6a68ec2f.zip | |
Introduce CategoryVisibilityPredicate, update JEI api
Diffstat (limited to 'runtime/src/main/java/me')
3 files changed, 40 insertions, 4 deletions
diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java index c9fd3b925..1e03b2ce7 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java @@ -23,9 +23,12 @@ package me.shedaniel.rei.impl.client.registry.category; +import dev.architectury.event.EventResult; +import me.shedaniel.rei.RoughlyEnoughItemsCore; import me.shedaniel.rei.api.client.plugins.REIClientPlugin; import me.shedaniel.rei.api.client.registry.category.ButtonArea; import me.shedaniel.rei.api.client.registry.category.CategoryRegistry; +import me.shedaniel.rei.api.client.registry.category.visibility.CategoryVisibilityPredicate; import me.shedaniel.rei.api.client.registry.display.DisplayCategory; import me.shedaniel.rei.api.common.category.CategoryIdentifier; import me.shedaniel.rei.api.common.display.Display; @@ -39,6 +42,7 @@ import java.util.function.Consumer; public class CategoryRegistryImpl implements CategoryRegistry { private final Map<CategoryIdentifier<?>, Configuration<?>> categories = new LinkedHashMap<>(); private final Map<CategoryIdentifier<?>, List<Consumer<CategoryConfiguration<?>>>> listeners = new HashMap<>(); + private final List<CategoryVisibilityPredicate> visibilityPredicates = new ArrayList<>(); @Override public void acceptPlugin(REIClientPlugin plugin) { @@ -90,6 +94,33 @@ public class CategoryRegistryImpl implements CategoryRegistry { return categories.size(); } + @Override + public void registerVisibilityPredicate(CategoryVisibilityPredicate predicate) { + visibilityPredicates.add(predicate); + visibilityPredicates.sort(Comparator.reverseOrder()); + } + + @Override + public boolean isCategoryVisible(DisplayCategory<?> category) { + for (CategoryVisibilityPredicate predicate : visibilityPredicates) { + try { + EventResult result = predicate.handleCategory(category); + if (result.interruptsFurtherEvaluation()) { + return result.isEmpty() || result.isTrue(); + } + } catch (Throwable throwable) { + RoughlyEnoughItemsCore.LOGGER.error("Failed to check if the category is visible!", throwable); + } + } + + return true; + } + + @Override + public List<CategoryVisibilityPredicate> getVisibilityPredicates() { + return Collections.unmodifiableList(visibilityPredicates); + } + private static class Configuration<T extends Display> implements CategoryConfiguration<T> { private final DisplayCategory<T> category; private final List<EntryIngredient> workstations = Collections.synchronizedList(new ArrayList<>()); diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java index 5d5c70789..4d57df4e6 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java @@ -23,6 +23,7 @@ package me.shedaniel.rei.impl.client.registry.display; +import com.google.common.base.Preconditions; import dev.architectury.event.EventResult; import me.shedaniel.rei.RoughlyEnoughItemsCore; import me.shedaniel.rei.api.client.plugins.REIClientPlugin; @@ -119,6 +120,7 @@ public class DisplayRegistryImpl extends RecipeManagerContextImpl<REIClientPlugi @Override public boolean isDisplayVisible(Display display) { DisplayCategory<Display> category = (DisplayCategory<Display>) CategoryRegistry.getInstance().get(display.getCategoryIdentifier()).getCategory(); + Preconditions.checkNotNull(category, "Failed to resolve category: " + display.getCategoryIdentifier()); for (DisplayVisibilityPredicate predicate : visibilityPredicates) { try { EventResult result = predicate.handleDisplay(category, display); @@ -126,7 +128,7 @@ public class DisplayRegistryImpl extends RecipeManagerContextImpl<REIClientPlugi return result.isEmpty() || result.isTrue(); } } catch (Throwable throwable) { - RoughlyEnoughItemsCore.LOGGER.error("Failed to check if the recipe is visible!", throwable); + RoughlyEnoughItemsCore.LOGGER.error("Failed to check if the display is visible!", throwable); } } diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/client/view/ViewsImpl.java b/runtime/src/main/java/me/shedaniel/rei/impl/client/view/ViewsImpl.java index a75e75698..46ba3eff0 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/client/view/ViewsImpl.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/client/view/ViewsImpl.java @@ -67,6 +67,7 @@ public class ViewsImpl implements Views { Map<DisplayCategory<?>, List<Display>> result = Maps.newLinkedHashMap(); for (CategoryRegistry.CategoryConfiguration<?> categoryConfiguration : CategoryRegistry.getInstance()) { DisplayCategory<?> category = categoryConfiguration.getCategory(); + if (CategoryRegistry.getInstance().isCategoryInvisible(category)) continue; CategoryIdentifier<?> categoryId = categoryConfiguration.getCategoryIdentifier(); List<Display> allRecipesFromCategory = displayRegistry.get((CategoryIdentifier<Display>) categoryId); @@ -126,15 +127,17 @@ public class ViewsImpl implements Views { for (Map.Entry<CategoryIdentifier<?>, List<DynamicDisplayGenerator<?>>> entry : displayRegistry.getCategoryDisplayGenerators().entrySet()) { CategoryIdentifier<?> categoryId = entry.getKey(); + DisplayCategory<?> category = CategoryRegistry.getInstance().get(categoryId).getCategory(); + if (CategoryRegistry.getInstance().isCategoryInvisible(category)) continue; Set<Display> set = new LinkedHashSet<>(); generatorsCount += entry.getValue().size(); - + for (DynamicDisplayGenerator<Display> generator : (List<DynamicDisplayGenerator<Display>>) (List<? extends DynamicDisplayGenerator<?>>) entry.getValue()) { generateLiveDisplays(displayRegistry, generator, builder, set::add); } - + if (!set.isEmpty()) { - CollectionUtils.getOrPutEmptyList(result, CategoryRegistry.getInstance().get(categoryId).getCategory()).addAll(set); + CollectionUtils.getOrPutEmptyList(result, category).addAll(set); } } |
