diff --git a/src/main/java/wayoftime/bloodmagic/core/util/PlayerUtil.java b/src/main/java/wayoftime/bloodmagic/core/util/PlayerUtil.java index ccd364f98..0b43952e4 100644 --- a/src/main/java/wayoftime/bloodmagic/core/util/PlayerUtil.java +++ b/src/main/java/wayoftime/bloodmagic/core/util/PlayerUtil.java @@ -1,16 +1,21 @@ package wayoftime.bloodmagic.core.util; +import java.util.ArrayList; +import java.util.List; import java.util.function.Predicate; import com.google.common.collect.Multimap; +import net.minecraft.core.NonNullList; import net.minecraft.world.entity.EquipmentSlot; import net.minecraft.world.entity.ai.attributes.Attribute; import net.minecraft.world.entity.ai.attributes.AttributeModifier; import net.minecraft.world.entity.player.Player; import net.minecraft.world.item.ItemStack; +import wayoftime.bloodmagic.BloodMagic; import wayoftime.bloodmagic.common.item.ExpandedArmor; import wayoftime.bloodmagic.core.living.LivingUtil; +import wayoftime.bloodmagic.util.helper.InventoryHelper; public class PlayerUtil { @@ -22,13 +27,36 @@ public static ItemStack findItem(Player player, Predicate requirement ItemStack offHand = player.getOffhandItem(); if (requirements.test(offHand)) return offHand; + List checkedInventories = new ArrayList<>(); + checkedInventories.add("offHandInventory"); - // Check inventory next - for (int slot = 0; slot < player.getInventory().getContainerSize(); slot++) + // Check Curios next, if available. + if (BloodMagic.curiosLoaded) { - ItemStack foundStack = player.getInventory().getItem(slot); - if (!foundStack.isEmpty() && requirements.test(foundStack)) - return foundStack; + NonNullList curiosInventory = InventoryHelper.getInventory(player, "curiosInventory"); + for (ItemStack item : curiosInventory) + { + if (requirements.test(item)) + return item; + } + checkedInventories.add("curiosInventory"); + } + + // Check Main Inventory next. + NonNullList mainInventory = InventoryHelper.getInventory(player, "mainInventory"); + for (ItemStack item : mainInventory) + { + if (requirements.test(item)) + return item; + } + checkedInventories.add("mainInventory"); + + // Check all remaining registered inventories. Armor and Add-ons. + NonNullList remainingInventories = InventoryHelper.getAllInventoriesExcluding(player, checkedInventories); + for (ItemStack item : remainingInventories) + { + if (requirements.test(item)) + return item; } return ItemStack.EMPTY; diff --git a/src/main/java/wayoftime/bloodmagic/util/Utils.java b/src/main/java/wayoftime/bloodmagic/util/Utils.java index a7093ffc7..15a8c9d21 100644 --- a/src/main/java/wayoftime/bloodmagic/util/Utils.java +++ b/src/main/java/wayoftime/bloodmagic/util/Utils.java @@ -8,6 +8,7 @@ import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; +import net.minecraft.core.NonNullList; import net.minecraft.nbt.CompoundTag; import net.minecraft.sounds.SoundEvents; import net.minecraft.sounds.SoundSource; @@ -43,6 +44,7 @@ import net.minecraftforge.items.wrapper.SidedInvWrapper; import wayoftime.bloodmagic.api.compat.IDemonWillViewer; import wayoftime.bloodmagic.common.tile.TileInventory; +import wayoftime.bloodmagic.util.helper.InventoryHelper; import wayoftime.bloodmagic.util.helper.NBTHelper; public class Utils @@ -571,55 +573,27 @@ public static ItemStack[] combineStacks(ItemStack stack1, ItemStack stack2) public static boolean canPlayerSeeDemonWill(Player player) { - IItemHandler inventory = new PlayerMainInvWrapper(player.getInventory()); - - for (int i = 0; i < inventory.getSlots(); i++) + NonNullList inventory = InventoryHelper.getActiveInventories(player); + for (ItemStack stack : inventory) { - ItemStack stack = inventory.getStackInSlot(i); - if (stack.isEmpty()) - { - continue; - } - if (stack.getItem() instanceof IDemonWillViewer && ((IDemonWillViewer) stack.getItem()).canSeeDemonWillAura(player.getCommandSenderWorld(), stack, player)) { return true; } } - - ItemStack offhandStack = player.getOffhandItem(); - if (!offhandStack.isEmpty() && offhandStack.getItem() instanceof IDemonWillViewer && ((IDemonWillViewer) offhandStack.getItem()).canSeeDemonWillAura(player.getCommandSenderWorld(), offhandStack, player)) - { - return true; - } - return false; } public static double getDemonWillResolution(Player player) { - IItemHandler inventory = new PlayerMainInvWrapper(player.getInventory()); - - for (int i = 0; i < inventory.getSlots(); i++) + NonNullList inventory = InventoryHelper.getActiveInventories(player); + for (ItemStack stack : inventory) { - ItemStack stack = inventory.getStackInSlot(i); - if (stack.isEmpty()) - { - continue; - } - if (stack.getItem() instanceof IDemonWillViewer && ((IDemonWillViewer) stack.getItem()).canSeeDemonWillAura(player.getCommandSenderWorld(), stack, player)) { return ((IDemonWillViewer) stack.getItem()).getDemonWillAuraResolution(player.getCommandSenderWorld(), stack, player); } } - - ItemStack offhandStack = player.getOffhandItem(); - if (!offhandStack.isEmpty() && offhandStack.getItem() instanceof IDemonWillViewer && ((IDemonWillViewer) offhandStack.getItem()).canSeeDemonWillAura(player.getCommandSenderWorld(), offhandStack, player)) - { - return ((IDemonWillViewer) offhandStack.getItem()).getDemonWillAuraResolution(player.getCommandSenderWorld(), offhandStack, player); - } - return 100; } diff --git a/src/main/java/wayoftime/bloodmagic/util/helper/InventoryHelper.java b/src/main/java/wayoftime/bloodmagic/util/helper/InventoryHelper.java index 57128ba06..b2259feed 100644 --- a/src/main/java/wayoftime/bloodmagic/util/helper/InventoryHelper.java +++ b/src/main/java/wayoftime/bloodmagic/util/helper/InventoryHelper.java @@ -1,5 +1,7 @@ package wayoftime.bloodmagic.util.helper; +import java.util.ArrayList; +import java.util.List; import java.util.Map; import java.util.function.Function; @@ -11,6 +13,21 @@ public class InventoryHelper { + private static Map>> inventoryProvider = BloodMagicAPI.INSTANCE.getInventoryProvider(); + + /** + * Gets all items from the specified inventory. + * + * @param player - The player who's inventories to check. + * @param inventoryKey - inventory's name. See BloodMagicCorePlugin for the vanilla ones. + * @return - NonNullList of all items in those inventories. + */ + public static NonNullList getInventory(Player player, String inventoryKey) + { + NonNullList inventory = NonNullList.create(); + inventory.addAll(inventoryProvider.get(inventoryKey).apply(player)); + return inventory; + } /** * Gets all items from all registered inventories. @@ -20,7 +37,6 @@ public class InventoryHelper */ public static NonNullList getAllInventories(Player player) { - Map>> inventoryProvider = BloodMagicAPI.INSTANCE.getInventoryProvider(); NonNullList inventory = NonNullList.create(); inventoryProvider.forEach((identifier, provider) -> inventory.addAll(provider.apply(player))); @@ -28,6 +44,22 @@ public static NonNullList getAllInventories(Player player) return inventory; } + /** + * Gets all items from all inventories, excluding the listed inventories + * + * @param player - The player who's inventories to check. + * @param excludedInventoryKeys - inventory keys to exclude. See BloodMagicCorePlugin for the vanilla ones. + * @return - NonNullList of all items in those inventories. + */ + public static NonNullList getAllInventoriesExcluding(Player player, List excludedInventoryKeys) + { + NonNullList inventory = NonNullList.create(); + + inventoryProvider.forEach((identifier, provider) -> {if (!identifier.equals(excludedInventoryKeys)) {inventory.addAll(provider.apply(player));}}); + + return inventory; + } + /** * Gets all items from all registered inventories marked as active as well as * main and off hand @@ -37,10 +69,10 @@ public static NonNullList getAllInventories(Player player) */ public static NonNullList getActiveInventories(Player player) { - Map>> inventoryProviders = BloodMagicAPI.INSTANCE.getActiveInventoryProvider(); + Map>> activeInventoryProvider = BloodMagicAPI.INSTANCE.getActiveInventoryProvider(); NonNullList inventories = NonNullList.create(); - inventoryProviders.forEach((identifier, provider) -> inventories.addAll(provider.apply(player))); + activeInventoryProvider.forEach((identifier, provider) -> inventories.addAll(provider.apply(player))); inventories.add(player.getItemInHand(InteractionHand.MAIN_HAND)); inventories.add(player.getItemInHand(InteractionHand.OFF_HAND)); diff --git a/src/main/resources/assets/bloodmagic/patchouli_books/guide/en_us/entries/alchemy_array/living_equipment/training_bracelet.json b/src/main/resources/assets/bloodmagic/patchouli_books/guide/en_us/entries/alchemy_array/living_equipment/training_bracelet.json index 24b1c09bc..f2dcc160d 100644 --- a/src/main/resources/assets/bloodmagic/patchouli_books/guide/en_us/entries/alchemy_array/living_equipment/training_bracelet.json +++ b/src/main/resources/assets/bloodmagic/patchouli_books/guide/en_us/entries/alchemy_array/living_equipment/training_bracelet.json @@ -11,7 +11,7 @@ "type": "bloodmagic:crafting_array", "heading": "Training Bracelet", "recipe": "bloodmagic:array/living_trainer", - "text": "$(italic)*Insert Rocky Training Montage here*$()" + "text": "$(italic)*Insert Rocky Training Montage here*$()$(br2)Only one of these bracelets will work at a time. Off-hand > Curios (if available) > Main Inventory (including main hand) > add-on inventories." }, { "type": "patchouli:image", diff --git a/src/main/resources/data/bloodmagic/curios/entities/bmplayerslots.json b/src/main/resources/data/bloodmagic/curios/entities/bmplayerslots.json index 57f4addc7..f0ec4e24c 100644 --- a/src/main/resources/data/bloodmagic/curios/entities/bmplayerslots.json +++ b/src/main/resources/data/bloodmagic/curios/entities/bmplayerslots.json @@ -3,6 +3,7 @@ "slots": [ "charm", "necklace", + "bracelet", "living_armour_socket" ] } \ No newline at end of file diff --git a/src/main/resources/data/curios/tags/items/bracelet.json b/src/main/resources/data/curios/tags/items/bracelet.json new file mode 100644 index 000000000..8fc77363c --- /dev/null +++ b/src/main/resources/data/curios/tags/items/bracelet.json @@ -0,0 +1,6 @@ +{ + "replace": false, + "values": [ + "bloodmagic:upgradetrainer" + ] +} \ No newline at end of file diff --git a/src/main/resources/data/curios/tags/items/charm.json b/src/main/resources/data/curios/tags/items/charm.json index e2c10b162..1aa8010aa 100644 --- a/src/main/resources/data/curios/tags/items/charm.json +++ b/src/main/resources/data/curios/tags/items/charm.json @@ -8,6 +8,8 @@ "bloodmagic:sigilofholding", "bloodmagic:divinationsigil", "bloodmagic:seersigil", - "bloodmagic:experiencebook" + "bloodmagic:sigilofsuppression", + "bloodmagic:experiencebook", + "bloodmagic:demonwillgauge" ] } \ No newline at end of file diff --git a/src/main/resources/data/curios/tags/items/living_armour_socket.json b/src/main/resources/data/curios/tags/items/living_armour_socket.json index 7ca41a545..fe2b98de6 100644 --- a/src/main/resources/data/curios/tags/items/living_armour_socket.json +++ b/src/main/resources/data/curios/tags/items/living_armour_socket.json @@ -8,10 +8,13 @@ "bloodmagic:sigilofholding", "bloodmagic:divinationsigil", "bloodmagic:seersigil", + "bloodmagic:sigilofsuppression", "bloodmagic:experiencebook", "bloodmagic:soulgempetty", "bloodmagic:soulgemlesser", "bloodmagic:soulgemcommon", - "bloodmagic:soulgemgreater" + "bloodmagic:soulgemgreater", + "bloodmagic:upgradetrainer", + "bloodmagic:demonwillgauge" ] } \ No newline at end of file