diff options
| author | shedaniel <daniel@shedaniel.me> | 2020-12-20 19:59:49 +0800 |
|---|---|---|
| committer | shedaniel <daniel@shedaniel.me> | 2020-12-20 19:59:49 +0800 |
| commit | 67171a5ff24ed77e6c4cc889543e8dfb543e8fe5 (patch) | |
| tree | 02909ac26d2b74ebf08f5c463f1b9a60483468df /api/src/main | |
| parent | 9784e9f7228fc0aa3ca814e3830dbd81996a3693 (diff) | |
| download | RoughlyEnoughItems-67171a5ff24ed77e6c4cc889543e8dfb543e8fe5.tar.gz RoughlyEnoughItems-67171a5ff24ed77e6c4cc889543e8dfb543e8fe5.tar.bz2 RoughlyEnoughItems-67171a5ff24ed77e6c4cc889543e8dfb543e8fe5.zip | |
wip more
Signed-off-by: shedaniel <daniel@shedaniel.me>
Diffstat (limited to 'api/src/main')
90 files changed, 8159 insertions, 0 deletions
diff --git a/api/src/main/java/me/shedaniel/rei/api/AutoTransferHandler.java b/api/src/main/java/me/shedaniel/rei/api/AutoTransferHandler.java new file mode 100644 index 000000000..743538410 --- /dev/null +++ b/api/src/main/java/me/shedaniel/rei/api/AutoTransferHandler.java @@ -0,0 +1,286 @@ +/* + * This file is licensed under the MIT License, part of Roughly Enough Items. + * Copyright (c) 2018, 2019, 2020 shedaniel + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + +package me.shedaniel.rei.api; + +import it.unimi.dsi.fastutil.ints.IntArrayList; +import it.unimi.dsi.fastutil.ints.IntList; +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; +import net.minecraft.client.Minecraft; +import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; +import net.minecraft.world.inventory.AbstractContainerMenu; +import org.jetbrains.annotations.ApiStatus; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +import java.util.function.Supplier; + +@Environment(EnvType.CLIENT) +public interface AutoTransferHandler { + + /** + * @return the priority of this handler, higher priorities will be called first. + */ + default double getPriority() { + return 0d; + } + + @NotNull + Result handle(@NotNull Context context); + + @ApiStatus.NonExtendable + interface Result { + /** + * Creates a successful result, no further handlers will be called. + */ + static Result createSuccessful() { + return new ResultImpl(); + } + + /** + * Creates a passing result, further handlers will be called. + * This will also mark the handler as not applicable. + */ + static Result createNotApplicable() { + return new ResultImpl(false); + } + + /** + * Creates a passing result, further handlers will be called. + * + * @param errorKey The error itself + */ + static Result createFailed(String errorKey) { + return new ResultImpl(errorKey, new IntArrayList(), 1744764928); + } + + /** + * Creates a passing result, further handlers will be called. + * The special color will be applied if this is the last handler. + * + * @param errorKey The error itself + * @param color A special color for the button + */ + static Result createFailedCustomButtonColor(String errorKey, int color) { + return new ResultImpl(errorKey, new IntArrayList(), color); + } + + /** + * Creates a passing result, further handlers will be called. + * + * @param errorKey The error itself + * @param redSlots A list of slots to be marked as red. Will be passed to {@link TransferRecipeCategory}. + */ + static Result createFailed(String errorKey, IntList redSlots) { + return new ResultImpl(errorKey, redSlots, 1744764928); + } + + /** + * Creates a passing result, further handlers will be called. + * The special color will be applied if this is the last handler. + * + * @param errorKey The error itself + * @param color A special color for the button + * @param redSlots A list of slots to be marked as red. Will be passed to {@link TransferRecipeCategory}. + */ + static Result createFailedCustomButtonColor(String errorKey, IntList redSlots, int color) { + return new ResultImpl(errorKey, redSlots, color); + } + + /** + * Forces this handler to be the last handler, no further handlers will be called. + */ + default Result blocksFurtherHandling() { + return blocksFurtherHandling(true); + } + + /** + * Forces this handler to be the last handler, no further handlers will be called. + */ + Result blocksFurtherHandling(boolean returnsToScreen); + + /** + * @return the color in which the button should be displayed in. + */ + int getColor(); + + /** + * @return whether this handler has successfully handled the transfer. + */ + boolean isSuccessful(); + + /** + * @return whether this handler should be the last handler. + */ + boolean isBlocking(); + + /** + * Applicable if {@link #isSuccessful()} is true. + * + * @return whether to return to the previous screen rather than staying open + */ + boolean isReturningToScreen(); + + /** + * @return whether the handler is applicable. + */ + boolean isApplicable(); + + /** + * Applicable if {@link #isSuccessful()} is false. + * + * @return the error message + */ + String getErrorKey(); + + /** + * @return a list of slots to be marked as red. Will be passed to {@link TransferRecipeCategory}. + */ + IntList getIntegers(); + } + + @ApiStatus.NonExtendable + interface Context { + static Context create(boolean actuallyCrafting, AbstractContainerScreen<?> containerScreen, RecipeDisplay recipeDisplay) { + return new ContextImpl(actuallyCrafting, containerScreen, () -> recipeDisplay); + } + + default Minecraft getMinecraft() { + return Minecraft.getInstance(); + } + + boolean isActuallyCrafting(); + + @Nullable + AbstractContainerScreen<?> getContainerScreen(); + + RecipeDisplay getRecipe(); + + @Nullable + default AbstractContainerMenu getContainer() { + return getContainerScreen() == null ? null : getContainerScreen().getMenu(); + } + } < |
