mirror of
https://github.com/GeyserMC/Geyser.git
synced 2025-01-05 10:24:35 +01:00
changes requested by reviewer
This commit is contained in:
parent
62d9deaa0d
commit
9efb855ca1
3 changed files with 43 additions and 17 deletions
|
@ -161,6 +161,14 @@ public interface NonVanillaCustomItemData extends CustomItemData {
|
||||||
return displayHandheld();
|
return displayHandheld();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #blockPlacer()} instead.
|
||||||
|
* Gets the block the item places.
|
||||||
|
*
|
||||||
|
* @return the block the item places
|
||||||
|
*/
|
||||||
|
String block();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the block placer settings, if it's null then the component won't be added.
|
* Gets the block placer settings, if it's null then the component won't be added.
|
||||||
*
|
*
|
||||||
|
@ -208,6 +216,12 @@ public interface NonVanillaCustomItemData extends CustomItemData {
|
||||||
|
|
||||||
Builder chargeable(boolean isChargeable);
|
Builder chargeable(boolean isChargeable);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #blockPlacer(CustomBlockPlacer)} instead.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
Builder block(String block);
|
||||||
|
|
||||||
Builder blockPlacer(CustomBlockPlacer blockPlacer);
|
Builder blockPlacer(CustomBlockPlacer blockPlacer);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -163,6 +163,11 @@ public final class GeyserNonVanillaCustomItemData extends GeyserCustomItemData i
|
||||||
return isChargeable;
|
return isChargeable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String block() {
|
||||||
|
return blockPlacer == null ? null : blockPlacer.block();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CustomBlockPlacer blockPlacer() {
|
public CustomBlockPlacer blockPlacer() {
|
||||||
return blockPlacer;
|
return blockPlacer;
|
||||||
|
@ -348,6 +353,12 @@ public final class GeyserNonVanillaCustomItemData extends GeyserCustomItemData i
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Builder block(String block) {
|
||||||
|
this.blockPlacer = new CustomBlockPlacer(block, false);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Builder blockPlacer(CustomBlockPlacer blockPlacer) {
|
public Builder blockPlacer(CustomBlockPlacer blockPlacer) {
|
||||||
this.blockPlacer = blockPlacer;
|
this.blockPlacer = blockPlacer;
|
||||||
|
|
|
@ -50,12 +50,7 @@ import org.geysermc.geyser.registry.type.GeyserMappingItem;
|
||||||
import org.geysermc.geyser.registry.type.ItemMapping;
|
import org.geysermc.geyser.registry.type.ItemMapping;
|
||||||
import org.geysermc.geyser.registry.type.NonVanillaItemRegistration;
|
import org.geysermc.geyser.registry.type.NonVanillaItemRegistration;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
public class CustomItemRegistryPopulator {
|
public class CustomItemRegistryPopulator {
|
||||||
public static void populate(Map<String, GeyserMappingItem> items, Multimap<String, CustomItemData> customItems, List<NonVanillaCustomItemData> nonVanillaCustomItems) {
|
public static void populate(Map<String, GeyserMappingItem> items, Multimap<String, CustomItemData> customItems, List<NonVanillaCustomItemData> nonVanillaCustomItems) {
|
||||||
|
@ -173,7 +168,7 @@ public class CustomItemRegistryPopulator {
|
||||||
NbtMapBuilder itemProperties = NbtMap.builder();
|
NbtMapBuilder itemProperties = NbtMap.builder();
|
||||||
NbtMapBuilder componentBuilder = NbtMap.builder();
|
NbtMapBuilder componentBuilder = NbtMap.builder();
|
||||||
|
|
||||||
setupBasicItemInfo(javaItem.maxDamage(), javaItem.maxStackSize(), mapping.getToolType() != null || customItemData.displayHandheld(), customItemData, itemProperties, componentBuilder, protocolVersion);
|
setupBasicItemInfo(javaItem.maxDamage(), javaItem.maxStackSize(), mapping.getToolType() != null || customItemData.displayHandheld(), false, customItemData, itemProperties, componentBuilder, protocolVersion);
|
||||||
|
|
||||||
boolean canDestroyInCreative = true;
|
boolean canDestroyInCreative = true;
|
||||||
if (mapping.getToolType() != null) { // This is not using the isTool boolean because it is not just a render type here.
|
if (mapping.getToolType() != null) { // This is not using the isTool boolean because it is not just a render type here.
|
||||||
|
@ -201,7 +196,8 @@ public class CustomItemRegistryPopulator {
|
||||||
case "minecraft:fire_charge", "minecraft:flint_and_steel" -> computeBlockItemProperties(new CustomBlockPlacer("minecraft:fire", false), componentBuilder);
|
case "minecraft:fire_charge", "minecraft:flint_and_steel" -> computeBlockItemProperties(new CustomBlockPlacer("minecraft:fire", false), componentBuilder);
|
||||||
case "minecraft:bow", "minecraft:crossbow", "minecraft:trident" -> computeChargeableProperties(itemProperties, componentBuilder, mapping.getBedrockIdentifier(), protocolVersion);
|
case "minecraft:bow", "minecraft:crossbow", "minecraft:trident" -> computeChargeableProperties(itemProperties, componentBuilder, mapping.getBedrockIdentifier(), protocolVersion);
|
||||||
case "minecraft:honey_bottle", "minecraft:milk_bucket", "minecraft:potion" -> computeConsumableProperties(itemProperties, componentBuilder, 2, true);
|
case "minecraft:honey_bottle", "minecraft:milk_bucket", "minecraft:potion" -> computeConsumableProperties(itemProperties, componentBuilder, 2, true);
|
||||||
case "minecraft:experience_bottle", "minecraft:egg", "minecraft:ender_pearl", "minecraft:ender_eye", "minecraft:lingering_potion", "minecraft:snowball", "minecraft:splash_potion" -> computeThrowableProperties(componentBuilder);
|
case "minecraft:experience_bottle", "minecraft:egg", "minecraft:ender_pearl", "minecraft:ender_eye", "minecraft:lingering_potion", "minecraft:snowball", "minecraft:splash_potion" ->
|
||||||
|
computeThrowableProperties(componentBuilder);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Hardcoded on Java, and should extend to the custom item
|
// Hardcoded on Java, and should extend to the custom item
|
||||||
|
@ -227,7 +223,10 @@ public class CustomItemRegistryPopulator {
|
||||||
NbtMapBuilder itemProperties = NbtMap.builder();
|
NbtMapBuilder itemProperties = NbtMap.builder();
|
||||||
NbtMapBuilder componentBuilder = NbtMap.builder();
|
NbtMapBuilder componentBuilder = NbtMap.builder();
|
||||||
|
|
||||||
setupBasicItemInfo(customItemData.maxDamage(), customItemData.stackSize(), displayHandheld, customItemData, itemProperties, componentBuilder, protocolVersion);
|
// this can replace minecraft:icon, so we have to add this here.
|
||||||
|
boolean replaceBlockItem = customItemData.blockPlacer() != null && customItemData.blockPlacer().replaceBlockItem();
|
||||||
|
|
||||||
|
setupBasicItemInfo(customItemData.maxDamage(), customItemData.stackSize(), displayHandheld, replaceBlockItem, customItemData, itemProperties, componentBuilder, protocolVersion);
|
||||||
|
|
||||||
boolean canDestroyInCreative = true;
|
boolean canDestroyInCreative = true;
|
||||||
if (customItemData.toolType() != null) { // This is not using the isTool boolean because it is not just a render type here.
|
if (customItemData.toolType() != null) { // This is not using the isTool boolean because it is not just a render type here.
|
||||||
|
@ -269,13 +268,15 @@ public class CustomItemRegistryPopulator {
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void setupBasicItemInfo(int maxDamage, int stackSize, boolean displayHandheld, CustomItemData customItemData, NbtMapBuilder itemProperties, NbtMapBuilder componentBuilder, int protocolVersion) {
|
private static void setupBasicItemInfo(int maxDamage, int stackSize, boolean displayHandheld, boolean replaceBlockItem, CustomItemData customItemData, NbtMapBuilder itemProperties, NbtMapBuilder componentBuilder, int protocolVersion) {
|
||||||
|
if (!replaceBlockItem) {
|
||||||
NbtMap iconMap = NbtMap.builder()
|
NbtMap iconMap = NbtMap.builder()
|
||||||
.putCompound("textures", NbtMap.builder()
|
.putCompound("textures", NbtMap.builder()
|
||||||
.putString("default", customItemData.icon())
|
.putString("default", customItemData.icon())
|
||||||
.build())
|
.build())
|
||||||
.build();
|
.build();
|
||||||
itemProperties.putCompound("minecraft:icon", iconMap);
|
itemProperties.putCompound("minecraft:icon", iconMap);
|
||||||
|
}
|
||||||
|
|
||||||
if (customItemData.creativeCategory().isPresent()) {
|
if (customItemData.creativeCategory().isPresent()) {
|
||||||
itemProperties.putInt("creative_category", customItemData.creativeCategory().getAsInt());
|
itemProperties.putInt("creative_category", customItemData.creativeCategory().getAsInt());
|
||||||
|
|
Loading…
Reference in a new issue