浏览代码

Add FuelRegistry (#81)

* Add FuelRegistry

Signed-off-by: shedaniel <daniel@shedaniel.me>

* Fix compilation

Signed-off-by: shedaniel <daniel@shedaniel.me>

* Remove redundant generic

Signed-off-by: shedaniel <daniel@shedaniel.me>

* Change to MinecraftForge.EVENT_BUS

Signed-off-by: shedaniel <daniel@shedaniel.me>

* A few docs, and switch to returning 0 for non-fuels

Signed-off-by: shedaniel <daniel@shedaniel.me>

* Bump to 1.13
shedaniel 4 年之前
父节点
当前提交
2eef26f632

+ 1 - 1
common/src/main/java/me/shedaniel/architectury/registry/BlockEntityRenderers.java

@@ -34,7 +34,7 @@ public final class BlockEntityRenderers {
     private BlockEntityRenderers() {}
     
     @ExpectPlatform
-    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<T>> provider) {
+    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<? super T>> provider) {
         throw new AssertionError();
     }
 }

+ 51 - 0
common/src/main/java/me/shedaniel/architectury/registry/fuel/FuelRegistry.java

@@ -0,0 +1,51 @@
+/*
+ * This file is part of architectury.
+ * Copyright (C) 2020, 2021 architectury
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+ */
+
+package me.shedaniel.architectury.registry.fuel;
+
+import me.shedaniel.architectury.annotations.ExpectPlatform;
+import net.minecraft.world.item.ItemStack;
+import net.minecraft.world.level.ItemLike;
+
+public final class FuelRegistry {
+    private FuelRegistry() {}
+    
+    /**
+     * Registers a burn time for items.
+     *
+     * @param time  the new burn time, use {@code 0} for non-fuel items,
+     *              and {@code -1} to use vanilla logic
+     * @param items the array of items to register for
+     */
+    @ExpectPlatform
+    public static void register(int time, ItemLike... items) {
+        throw new AssertionError();
+    }
+    
+    /**
+     * Returns the burn time of an {@link ItemStack}.
+     *
+     * @param stack the stack
+     * @return the burn time of the stack, returns {@code 0} if not a fuel
+     */
+    @ExpectPlatform
+    public static int get(ItemStack stack) {
+        throw new AssertionError();
+    }
+}

+ 1 - 1
fabric/src/main/java/me/shedaniel/architectury/registry/fabric/BlockEntityRenderersImpl.java

@@ -28,7 +28,7 @@ import net.minecraft.world.level.block.entity.BlockEntityType;
 import java.util.function.Function;
 
 public class BlockEntityRenderersImpl {
-    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<T>> provider) {
+    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<? super T>> provider) {
         BlockEntityRendererRegistry.INSTANCE.register(type, provider);
     }
 }

+ 41 - 0
fabric/src/main/java/me/shedaniel/architectury/registry/fuel/fabric/FuelRegistryImpl.java

@@ -0,0 +1,41 @@
+/*
+ * This file is part of architectury.
+ * Copyright (C) 2020, 2021 architectury
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+ */
+
+package me.shedaniel.architectury.registry.fuel.fabric;
+
+import net.fabricmc.fabric.api.registry.FuelRegistry;
+import net.minecraft.world.item.ItemStack;
+import net.minecraft.world.level.ItemLike;
+
+public class FuelRegistryImpl {
+    public static void register(int time, ItemLike... items) {
+        for (ItemLike item : items) {
+            if (time >= 0) {
+                FuelRegistry.INSTANCE.add(item, time);
+            } else {
+                FuelRegistry.INSTANCE.remove(item);
+            }
+        }
+    }
+    
+    public static int get(ItemStack stack) {
+        Integer time = FuelRegistry.INSTANCE.get(stack.getItem());
+        return time == null ? 0 : time;
+    }
+}

+ 1 - 1
forge/src/main/java/me/shedaniel/architectury/registry/forge/BlockEntityRenderersImpl.java

@@ -28,7 +28,7 @@ import net.minecraftforge.fml.client.registry.ClientRegistry;
 import java.util.function.Function;
 
 public class BlockEntityRenderersImpl {
-    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<T>> provider) {
+    public static <T extends BlockEntity> void registerRenderer(BlockEntityType<T> type, Function<BlockEntityRenderDispatcher, BlockEntityRenderer<? super T>> provider) {
         ClientRegistry.bindTileEntityRenderer(type, provider);
     }
 }

+ 56 - 0
forge/src/main/java/me/shedaniel/architectury/registry/fuel/forge/FuelRegistryImpl.java

@@ -0,0 +1,56 @@
+/*
+ * This file is part of architectury.
+ * Copyright (C) 2020, 2021 architectury
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+ */
+
+package me.shedaniel.architectury.registry.fuel.forge;
+
+import it.unimi.dsi.fastutil.objects.Object2IntLinkedOpenHashMap;
+import it.unimi.dsi.fastutil.objects.Object2IntMap;
+import net.minecraft.world.item.ItemStack;
+import net.minecraft.world.level.ItemLike;
+import net.minecraftforge.common.ForgeHooks;
+import net.minecraftforge.common.MinecraftForge;
+import net.minecraftforge.event.furnace.FurnaceFuelBurnTimeEvent;
+import net.minecraftforge.eventbus.api.SubscribeEvent;
+
+public class FuelRegistryImpl {
+    private static final Object2IntMap<ItemLike> ITEMS = new Object2IntLinkedOpenHashMap<>();
+    
+    static {
+        MinecraftForge.EVENT_BUS.register(FuelRegistryImpl.class);
+    }
+    
+    public static void register(int time, ItemLike... items) {
+        for (ItemLike item : items) {
+            ITEMS.put(item, time);
+        }
+    }
+    
+    public static int get(ItemStack stack) {
+        return ForgeHooks.getBurnTime(stack);
+    }
+    
+    @SubscribeEvent
+    public static void event(FurnaceFuelBurnTimeEvent event) {
+        if (event.getItemStack().isEmpty()) return;
+        int time = ITEMS.getOrDefault(event.getItemStack().getItem(), Integer.MIN_VALUE);
+        if (time != Integer.MIN_VALUE) {
+            event.setBurnTime(time);
+        }
+    }
+}

+ 2 - 2
gradle.properties

@@ -6,11 +6,11 @@ supported_version=1.16.4/5
 
 archives_base_name=architectury
 archives_base_name_snapshot=architectury-snapshot
-base_version=1.12
+base_version=1.13
 maven_group=me.shedaniel
 
 fabric_loader_version=0.11.1
-fabric_api_version=0.30.3+1.16
+fabric_api_version=0.34.2+1.16
 mod_menu_version=1.14.6+
 
 forge_version=36.0.42